1.迁移数据前先设置mysql服务器参数
innodb_large_prefix=ON
2.远程分别导出base和store数据库命令
导出测试环境base数据库
mysqldump --user=timesll@timesll-test-mysql --password='' --column-statistics=0 --host=timesll-test-mysql.mysql.database.chinacloudapi.cn --port=3306 --result-file="basedump.sql" --databases "base"
导出测试环境store数据库
mysqldump --user=timesll@timesll-test-mysql --password='' --column-statistics=0 --host=timesll-test-mysql.mysql.database.chinacloudapi.cn --port=3306 --result-file="storedump.sql" --databases "store"
参数说明:
--user 数据库用户名
--password 数据库密码
--host 数据库连接地址
--port 数据库端口号
--result-file 导出的文件名称
--databases 要导出的数据库
3.验证导出的sql头文件
可以使用vi命令,确认use后的名称是即将要导出到的库,如果不是需要手动更改。
4.将导出的数据导入到新库
将步骤2导出的数据库执行以下命令分别导入新的库环境,注意替换为环境的实际连接信息。
导入新base库
mysql -h 127.0.0.1 -u dev -p base 导入新sore库
mysql -h 127.0.0.1 -u dev -p store 5.迁移完对数据完整性验证
方法1:
mysqldump --skip-comments --skip-extended-insert -u root -p dbName1>file1.sqlmysqldump --skip-comments --skip-extended-insert -u root -p dbName2>file2.sqldiff file1.sql file2.sql
方法2:
mysqldbcompare --server1=dev:'password'@rm-wz92lk20v9bp2bt93io.mysql.rds.aliyuncs.com --server2='timesll@timesll-test-mysql':'password'@timesll-test-mysql.mysql.database.chinacloudapi.cn --diffftype=sql base:base