共计 1443 个字符,预计需要花费 4 分钟才能阅读完成。
环境为 CentOS 7.2+MySQL 5.7,网上教程很多,原理也不复杂(深知自己踩的坑还不够)
正常情况下,配置起来比较简单。另外,根据个人感受,MySQL 的复制感觉要比 SQL Server 的复制要清爽很多(尽管功能上可能有一些差异)。
CentOS 6.7 X64 下 MySQL5.1.73 和 5.5.32 主从复制服务配置实战 http://www.linuxidc.com/Linux/2017-04/142770.htm
MySQL 主从复制配置 + MySQL Router 部署使用测试 http://www.linuxidc.com/Linux/2017-04/142771.htm
MySQL 主从复制与主主复制 http://www.linuxidc.com/Linux/2017-04/142624.htm
CentOS 搭建 MySQL 主从复制,读写分离 http://www.linuxidc.com/Linux/2016-09/135121.htm
MySQL 主从复制原理及其配置步骤简述 http://www.linuxidc.com/Linux/2017-05/143289.htm
MySQL5.6 主从复制搭建基于日志(binlog)http://www.linuxidc.com/Linux/2017-05/144162.htm
CentOS 7.2 下 MySQL5.7.13 安装和基于 SSL 加密的主从复制 http://www.linuxidc.com/Linux/2017-05/144038.htm
master 服务器,首先是开启了二进制日志,同时设置 server-id 为一个具体的数值
1,创建复制用户
GRANT REPLICATION SLAVE ON *.* to ‘repl_test’@’120.77.147.***’ identified by ‘123456’;
2,记录 master 日志文件和日志位置
show master status;
从库上
1,设置主服务器
CHANGE MASTER TO
MASTER_HOST=’120.77.159.***’,
MASTER_USER=’repl_test’,
MASTER_PASSWORD=’123456′,
MASTER_PORT = 8000,
MASTER_LOG_FILE=’mysql-bin.000047′,
MASTER_LOG_POS=3112;
2,启动从服务器上的复制
start slave;
show slave status 查看丛库的状态
数据同步测试
主服务器上创建一个新的 DB,随即同步到从服务器
主服务器上创建一个表,写入数据,也同步到从服务器上(阿里云免费申请的两台 ECS 云服务器,主从延迟很小,感觉不超过 1 秒)
中间遇到一点小问题,在 show slave status 的时候,发现 Slave_IO_Running 是正常启动的,但是 Slave_SQL_Running 没有启动
Slave_IO_Running: Yes
Slave_SQL_Running: No
参考 http://www.linuxidc.com/Linux/2014-02/96945.htm 这里之后,解决
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1; 客户端运行,用来跳过几个事件,只有当同步进程出现错误而停止的时候才可以执行。
stop slave ;
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
start slave