X之后内置了读写分离的功能,在这里介绍一下mysql上主从的配置步骤
两台服务器
主库(Master)为: 10.0.4.158
从库(Slave)为:10.0.4.162
主从服务器的MySQL版本一致
一、登录Master服务器,修改my.ini ,添加如下内容:
- #数据库ID号, 为1时表示为Master,其中master_id必须为1到232–1之间的一个正整数值;
- server-id = 1
- #启用二进制日志;
- log-bin=mysql-bin
- #需要同步的二进制数据库名;
- binlog-do-db=ultrax
- #不同步的二进制数据库名,如果不设置可以将其注释掉;
- binlog-ignore-db=mysql
- #设定生成的log文件名;
- log-bin="E:/Database/materlog"
- #把更新的记录写到二进制文件中;
- log-slave-updates
- #跳过错误,继续执行复制;
- slave-skip-errors
配置完重启 mysql
二、在主库建立 slave 复制所要使用的用户;
- mysql>grant replication slave on *.* to forslave@10.0.4.162 identified by '********';
三、将主库中以上配置的需要同步的 ultrax 库的数据 备份到 从库中
四、登录Slave数据库服务器,修改my.ini;
- #如果需要增加Slave库则,此id往后顺延;
- server-id = 2
- log-bin=mysql-bin
- #主库host
- master-host = 10.0.4.158
- #上面刚才建立的复制使用的用户
- master-user = forslave
- master-password = ******
- master-port = 3306
- #如果发现主服务器断线,重新连接的时间差;
- master-connect-retry=60
- #不需要备份的数据库;
- replicate-ignore-db=mysql
- #需要备份的数据库
- replicate-do-db=ultrax
- log-slave-update
- slave-skip-errors
配置完成后,重启 从库的mysql
五、启动 slave ,并查看slave 状态是否正常;
- mysql>slave start;
- mysql>show slave status\G;
状态如下图所示:
另外需要在使用命令在主库那查看一下
- mysql> show master status;
查看Master上面的状态,以保证从库的状态与 主库的一致;