可以在Linux服务器上复制整个MySQL数据库吗?
我知道可以使用导出和导入的方法,但原始数据库大小超过25MB,所以这不是理想的选择。
是否可以使用Mysqldump或直接复制数据库文件来实现?
我知道可以使用导出和导入的方法,但原始数据库大小超过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 --add-drop-table -u wordpress -p wordpress | mysql -u wordpress -p wordpress_backup
mysqldump -u user -p'password' db-name | ssh user@some_far_place.com mysql -u user -p'password' db-name
-p[password]之间不要有空格
复制数据库
# mysqldump -u root -p password db1 > dump.sql
# mysqladmin -u root -p password create db2
# mysql -u root -p password db2 < dump.sql
这种方法对于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
:: 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: https://dev59.com/6nI-5IYBdhLWcg3wYXL8
@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!!!
这对我来说在命令提示符下有效,从mysql shell之外:
# mysqldump -u root -p password db1 > dump.sql
# mysqladmin -u root -p password create db2
# mysql -u root -p password db2 < dump.sql
这对我来说看起来是最好的方法。如果压缩“dump.sql”,您可以将其简单地存储为压缩备份。太棒了! 对于一个具有Innodb表的1GB数据库,创建“dump.sql”约需要一分钟,并将数据转储到新的DB db2约需要三分钟。
直接复制整个db目录(mysql/data/db1)对我不起作用,我想这是因为InnoDB表的原因。
对我来说,以下代码行解决了问题
mysqldump --quote-names -q -u username1 --password='password1' originalDB | mysql -u username2 --password='password2' duplicateDB
曾经在MySQL中,你可以直接将所有表文件复制到mysql树的另一个目录中。
mysql cli - 创建数据库db2
linux cli - cp db1 db2
--routines
选项。 - LinuxDevOps〜/ .bash_history
文件中编辑它。或者,您还可以将第一个命令的结果输出到临时文件中,并在其后执行以下操作(这将提示您输入密码)mysql -p -u admin duplicatedb < temporaryfile.sql
。 - Mike