不同云服务器如何实现mysql数据库同步

下文给大家带来关于不同云服务器如何实现MySQL数据库同步,感兴趣的话就一起来看看这篇文章吧,相信看完不同云服务器如何实现mysql数据库同步对大家多少有点帮助吧。

成都创新互联-专业网站定制、快速模板网站建设、高性价比伍家岗网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式伍家岗网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖伍家岗地区。费用合理售后完善,十年实体公司更值得信赖。

目标:

A云服务器上自建的数据库同步到B云服务器上自建的数据库。

阿里云的RDS数据库A同步到B云服务器上自建的数据库。

A的数据库名为:mytest

基础:linux,会配置my.cnf

开始:

下面称前者A为主云服务器,后者B为从云服务器。

  1. 先在A云服务器查看:sql语句:show master status;

    得到File,Position 的值。

    'mysql-bin.000039', '1538',  (这个后面要用到)

  2. 在B云服务器,修改:/etc/my.cnf.

    修改前,先停止mysql.

增加这几句:

server-id = 2
expire_logs_days = 10
max_binlog_size = 100M
replicate-do-db = mytest
replicate-ignore-db = mysql
replicate-ignore-db = information_schema
replicate-ignore-db = preformance_schema
slave-skip-errors=all
#GTID
gtid_mode=on
enforce_gtid_consistency=on
binlog_format=row
log-slave-updates=1

修改后,再重启mysql.

3.B云服务器,进入mysql

mysql>show slave status\G;

查看从云服务器状态。

如有,则停止。

mysql>stop slave;

然后写这一句:

mysql>change master to master_host='*********',master_port=3306,master_user='******',master_password='*******',master_log_file='mysql-bin.000039' ,master_log_pos=1538;

master_log_file='mysql-bin.000039' ,master_log_pos=1538;就是上面A云服务器查到的。

在执行这一句时,可能因为之前的slave没清除,会报错,

mysql> reset slave all;

即可。

重启 ,

mysql>start slave;

再查看,

mysql>show slave status\G;

有这三句,就对了!

Slave_IO_State: Waiting for master to send event

Slave_IO_Running:Yes;

Slave_SQL_Runing:Yes;

之后,A云服务器中mytest数据库的更新,都会同步到B云服务器。

比如,新建一张表,B云服务器刷新后,也看到新建一张表。

3.补充一点,如果B云服务器只需要同步部分数据表。

可以修改B云服务器的my.cnf,增加

replicate-do-table=db_name1.table_name1

replicate-do-table=db_name1.table_name2

replicate-do-table=db_name2.table_name1

看了以上关于不同云服务器如何实现mysql数据库同步详细内容,是否有所收获。如果想要了解更多相关,可以继续关注我们的行业资讯板块。


文章标题:不同云服务器如何实现mysql数据库同步
链接分享:http://ybzwz.com/article/igddsg.html