温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-05-28 11:40:46 来源:网络 阅读:482 作者:三月 栏目:MySQL数据库

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

目标:

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数据库同步详细内容,是否有所收获。如果想要了解更多相关,可以继续关注我们的行业资讯板块。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI