[mysql] 전체 MySQL 데이터베이스 복제

Linux 서버에서 전체 MySQL 데이터베이스를 복제 할 수 있습니까?

내보내기 및 가져 오기를 사용할 수 있지만 원래 데이터베이스는 25MB 이상이므로 이상적이지 않습니다.

mysqldump를 사용하거나 데이터베이스 파일을 직접 복제하여 가능합니까?



답변

먼저 중복 데이터베이스를 만듭니다.

CREATE DATABASE duplicateddb;

사용자와 권한이 모두 제자리에 있는지 확인하고 다음을 수행하십시오.

 mysqldump -u admin -p originaldb | mysql -u backup -pPassword duplicateddb;


답변

원격 서버로

mysqldump mydbname | ssh host2 "mysql mydbcopy"

로컬 서버로

mysqldump mydbname | mysql mydbcopy


답변

때때로 mysqldump를 수행하고 출력을 다른 mysql 명령으로 파이프하여 다른 데이터베이스로 가져옵니다.

mysqldump --add-drop-table -u wordpress -p wordpress | mysql -u wordpress -p wordpress_backup


답변

데이터가있는 시스템에 mysqldump 파일을 만들고 파이프를 사용하여이 mysqldump 파일을 새 시스템에 대한 입력으로 제공합니다. 새 시스템은 ssh 명령을 사용하여 연결할 수 있습니다.

mysqldump -u user -p'password' db-name | ssh user@some_far_place.com mysql -u user -p'password' db-name

-p [password] 사이에 공백이 없습니다.


답변

여기에 Vincent와 Pauls의 제안을 결합한 Windows bat 파일이 있습니다. 사용자에게 소스 및 대상 이름을 묻는 메시지가 표시됩니다.

실행 파일 / 데이터베이스 포트에 대한 적절한 경로를 설정하려면 상단의 변수를 수정하기 만하면됩니다.

:: Creates a copy of a database with a different name.
:: User is prompted for Src and destination name.
:: Fair Warning: passwords are passed in on the cmd line, modify the script with -p instead if security is an issue.
:: Uncomment the rem'd out lines if you want script to prompt for database username, password, etc.

:: See also: http://stackoverflow.com/questions/1887964/duplicate-entire-mysql-database

@set MYSQL_HOME="C:\sugarcrm\mysql\bin"
@set mysqldump_exec=%MYSQL_HOME%\mysqldump
@set mysql_exec=%MYSQL_HOME%\mysql
@set SRC_PORT=3306
@set DEST_PORT=3306
@set USERNAME=TODO_USERNAME
@set PASSWORD=TODO_PASSWORD

:: COMMENT any of the 4 lines below if you don't want to be prompted for these each time and use defaults above.
@SET /p USERNAME=Enter database username:
@SET /p PASSWORD=Enter database password:
@SET /p SRC_PORT=Enter SRC database port (usually 3306):
@SET /p DEST_PORT=Enter DEST database port:

%MYSQL_HOME%\mysql --user=%USERNAME% --password=%PASSWORD% --port=%DEST_PORT% --execute="show databases;"
@IF NOT "%ERRORLEVEL%" == "0" GOTO ExitScript

@SET /p SRC_DB=What is the name of the SRC Database:
@SET /p DEST_DB=What is the name for the destination database (that will be created):

%mysql_exec% --user=%USERNAME% --password=%PASSWORD% --port=%DEST_PORT% --execute="create database %DEST_DB%;"
%mysqldump_exec% --add-drop-table --user=%USERNAME% --password=%PASSWORD% --port=%SRC_PORT% %SRC_DB% | %mysql_exec% --user=%USERNAME% --password=%PASSWORD% --port=%DEST_PORT% %DEST_DB%
@echo SUCCESSFUL!!!
@GOTO ExitSuccess

:ExitScript
@echo "Failed to copy database"
:ExitSuccess

샘플 출력 :

C:\sugarcrm_backups\SCRIPTS>copy_db.bat
Enter database username: root
Enter database password: MyPassword
Enter SRC database port (usually 3306): 3308
Enter DEST database port: 3308

C:\sugarcrm_backups\SCRIPTS>"C:\sugarcrm\mysql\bin"\mysql --user=root --password=MyPassword --port=3308 --execute="show databases;"
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sugarcrm_550_pro   |
| sugarcrm_550_ce    |
| sugarcrm_640_pro   |
| sugarcrm_640_ce    |
+--------------------+
What is the name of the SRC Database:  sugarcrm
What is the name for the destination database (that will be created):  sugarcrm_640_ce

C:\sugarcrm_backups\SCRIPTS>"C:\sugarcrm\mysql\bin"\mysql --user=root --password=MyPassword --port=3308 --execute="create database sugarcrm_640_ce;"

C:\sugarcrm_backups\SCRIPTS>"C:\sugarcrm\mysql\bin"\mysqldump --add-drop-table --user=root --password=MyPassword --port=3308 sugarcrm   | "C:\sugarcrm\mysql\bin"\mysql --user=root --password=MyPassword --port=3308 sugarcrm_640_ce
SUCCESSFUL!!!


답변

InnoDB에서는 작동하지 않습니다. MyISAM 데이터베이스를 복사하려는 경우에만이 해결 방법을 사용하십시오.

백업 중에 테이블을 잠그고 데이터베이스 가져 오기 중에 MySQL을 일시 중지하는 것이 허용되는 경우 mysqlhotcopy 가 더 빠르게 작동 할 수 있습니다.

지원:

# mysqlhotcopy -u root -p password db_name /path/to/backup/directory

복원:

cp /path/to/backup/directory/* /var/lib/mysql/db_name

mysqlhotcopy 는 또한 SSH (scp)를 통해 파일을 전송할 수 있으며, 가능하면 중복 데이터베이스 디렉토리로 바로 전송할 수 있습니다.

# mysqlhotcopy -u root -p password db_name /var/lib/mysql/duplicate_db_name


답변

데이터베이스 복사본 만들기

# mysqldump -u root -p password db1 > dump.sql
# mysqladmin -u root -p password create db2
# mysql -u root -p password db2 < dump.sql