• 1
  • 2
  • 3
  • 4
  • 5
mysql数据库问题 首 页  »  帮助中心  »  数据库  »  mysql数据库问题
关于采用MySQLdump工具迁移优缺点及流程
发布日期:2015-11-10 15:11:6

  关于采用MySQLdump工具迁移优缺点及流程

  该方案缺点是停机时间较长,优点是简单,容易上手;。 因此它适用于允许停机的时间较长,并且在这个时间范围内能够完成,或者数据量不大。

  由于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

  其中

  db_name 以您真实的数据库名代替

        local_ip 以您真实的线下MySQL服务器IP地址代替

  user_name 以您真实的数据库用户代替

  /tmp/db_name.sql是文件名,由您自己随意填写。

  4、备份您线下原有数据库的存储过程、触发器和函数(若您数据库中没有使用存储过程、触发器和函数,则跳过这步),为了兼容RDS,在导出存储过程、触发器和函数时,需要将definer去掉。具体命令如下:

  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

  其中

  /tmp/trigger_procedure.sql是文件名,由您自己随意填写。

         local_ip 以您真实的线下MySQL服务器IP地址代替

  user_name 以您真实的数据库用户代替

  db_name 以您真实的数据库名代替

  5、将存储过程文件和数据文件上传到已经购买的云服务器中。

  6、远程登录到云服务器,将刚才上传的数据文件导入到已购买的RDS实例中。具体命令如下:

  mysql -hexample.mysql.rds.aliyuncs.com –uuserName -p dbName < /tmp/dbName.sql

  其中

  /tmp/db_name.sql是刚才前面您导出的数据文件名称

        example.mysql.rds.aliyuncs.com:RDS实例连接地址;

  user_name 以您真实的RDS数据库用户代替

  db_name 以您真实的RDS数据库名代替

  7、远程登录到云服务器,将刚才上传的存储过程文件(包含触发器、存储过程和函数,若没有则请跳过此步)导入到已购买的RDS实例中。具体命令如下:

  mysql -h example.mysql.rds.aliyuncs.com -u userName -p dbName < /tmp/triggerProcedure.sql

  其中

  /tmp/trigger_procedure.sql是刚才前面您导出的存储过程文件名称

        example.mysql.rds.aliyuncs.com:RDS实例连接地址;

  user_name 以您真实的RDS数据库用户代替

  db_name 以您真实的RDS数据库名代替

  至此数据迁移完毕,可以对RDS正常使用。用户可使用第三方数据库管理工具(如phpmyadmin)或数据库客户端工具(如MySQL-Front)以及程序的方式,通过端口号和域名连接数据库,在输入正确的用户名和密码后即可登陆DB进行操作和开发。

  如问题还未解决,请联系售后技术支持。