目标:

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


网上几篇文章,比较详细。也可以参考。再有问题。欢迎加入PHP技术问答群提问。


谢谢阅读。



主从同步数据库:

http://blog.csdn.net/chenzenan/article/details/44198053
https://yq.aliyun.com/articles/66087

https://yq.aliyun.com/articles/9044


双向同步数据库:

http://blog.csdn.net/chenhongwu666/article/details/54358449


----------  招募未来大神 -----------------------

如果您有利他之心,乐于帮助他人,乐于分享
如果您遇到php问题,百度且问了其他群之后仍没得到解答

欢迎加入,PHP技术问答群,QQ群:292626152

教学相长!帮助他人,自己也会得到提升!

为了珍惜每个人的宝贵时间,请大家不要闲聊!

愿我们互相帮助,共同进步!

加入时留言暗号,php,ajax,thinkphp,yii...