该方案优点是简单,容易上手;缺点是停机时间较长。 因此它适用于数据量不大,或者允许停机的时间较长,并且在这个时间范围内能够完成。
由于RDS提供的关系数据库服务与原生的数据库服务是完全兼容的,所以对于用户来说,从原有数据库迁移到RDS数据的过程,与从一个mysql服务器迁移到另外一台mysql服务器的过程基本类似。具体的迁移流程如下:
1、 开通云服务器服务。
2、 开通RDS服务,如果开通成功,会返回给用户连接地址和端口,比如cloudcc.mysql.rds.aliyuncs.com:3306。
3、 先停止业务,使用MySQLdump的数据导出工具,将您线下原有数据库数据导出为数据文件((本步骤仅仅导出数据,不包括存储过程,函数,触发器)。具体命令如下:
mysqldump
-h local_ip -u user_name -p --opt --default-character-set=utf8
--hex-blob db_name --skip-triggers > /tmp/db_name.sql
其中
local_ip 以您真实的线下MySQL服务器IP地址代替
user_name 以您真实的数据库用户代替
db_name 以您真实的数据库名代替
/tmp/db_name.sql是文件名,由您自己随意填写。
4、备份您线下原有数据库的存储过程、触发器和函数(若您数据库中没有使用存储过程、触发器和函数,则跳过这步),在导出存储过程、触发器和函数时,需要将definer去掉,以兼容RDS。具体命令如下:
mysqldump -h local_ip -u user_name -p --opt --default-character-set=utf8 --hex-blob db_name –triggers -d -t -R | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/' > /tmp/trigger_procedure.sql
其中
local_ip 以您真实的线下MySQL服务器IP地址代替
user_name 以您真实的数据库用户代替
db_name 以您真实的数据库名代替
/tmp/trigger_procedure.sql是文件名,由您自己随意填写。
5、将数据文件和存储过程文件上传到已经购买的云服务器中。
6、远程登录到云服务器,将刚才上传的数据文件导入到已购买的RDS实例中。具体命令如下:
mysql -hexample.mysql.rds.aliyuncs.com –uuserName -p dbName < /tmp/dbName.sql
其中
example.mysql.rds.aliyuncs.com:RDS实例连接地址;
user_name 以您真实的RDS数据库用户代替
db_name 以您真实的RDS数据库名代替
/tmp/db_name.sql是刚才前面您导出的数据文件名称
7、远程登录到云服务器,将刚才上传的存储过程文件(包含存储过程、触发器和函数,若没有则请跳过此步)导入到已购买的RDS实例中。具体命令如下:
mysql -h example.mysql.rds.aliyuncs.com -u userName -p dbName < /tmp/triggerProcedure.sql
其中
example.mysql.rds.aliyuncs.com:RDS实例连接地址;
user_name 以您真实的RDS数据库用户代替
db_name 以您真实的RDS数据库名代替
/tmp/trigger_procedure.sql是刚才前面您导出的存储过程文件名称
至此数据迁移完毕,可以对RDS正常使用。用户可使用数据库客户端工具(如MySQL-Front)或第三方数据库管理工具(如phpmyadmin)以及程序的方式,通过域名和端口号连接数据库,在输入正确的用户名和密码后即可登录DB进行操作和开发。