下文给大家带来关于不同云服务器如何实现mysql数据库同步,感兴趣的话就一起来看看这篇文章吧,相信看完不同云服务器如何实现mysql数据库同步对大家多少有点帮助吧。
目标:
A云服务器上自建的数据库同步到B云服务器上自建的数据库。
阿里云的RDS数据库A同步到B云服务器上自建的数据库。
A的数据库名为:mytest
基础:linux,会配置my.cnf
开始:
下面称前者A为主云服务器,后者B为从云服务器。
先在A云服务器查看:sql语句:show master status;
得到File,Position 的值。
'mysql-bin.000039', '1538', (这个后面要用到)
在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数据库同步详细内容,是否有所收获。如果想要了解更多相关,可以继续关注我们的行业资讯板块。