一、导读
最近学习,mysql的读写分离技术,这篇文章是读写分离的基础,今天就给大家一起来搭建一个主从复制的mysql。
二、准备环境
- 准备2个版本一致的mysql数据库 (我的是centos系统装的2个mysql,一个宿主机上的mysql,一个是docker的mysql)
- 实现MySQL主从复制需要进行的配置:
- 主服务器:
- 开启二进制日志
- 配置唯一的server-id
- 从服务器:
- 配置唯一的server-id
- 使用master分配的用户账号读取master二进制日志
- 启用slave服务
三、配置主mysql
- 修改mysql配置
找到主数据库的配置文件my.cnf,我的在/etc/mysql/my.cnf,插入如下两行
log-bin=mysql-bin #开启二进制日志
server-id=1 #设置server-id
- 重启mysql
- 查看主mysql的状态,使用如下命令查询,记住File 和 Position 两个值。
SHOW MASTER STATUS;
结果如下:
File | Position |
---|---|
mysql-bin.000005 | 3895 |
四、配置从mysql
- 同样找到my.cnf配置文件,里面添加server-id
server-id=2 #设置server-id,必须和上面的主mysql的id不一样,唯一
- 重启mysql
- 停止slave
用户登录,执行如下命令:
stop slave
- 执行同步SQL语句(需要主服务器主机名,登陆凭据,二进制文件的名称和位置):
执行如下命令:
CHANGE MASTER TO MASTER_HOST=‘172.17.0.1’, MASTER_USER=‘root’, MASTER_PASSWORD=‘admin’, MASTER_LOG_FILE=‘mysql-bin.000005’, MASTER_LOG_POS=120;
解释:
MASTER_HOST 是主mysql的ip地址
MASTER_USER 是主mysql的用户
MASTER_PASSWORD 是主mysql用户对应的登录密码
MASTER_LOG_FILE 是主mysql的File值
MASTER_LOG_POS 是主mysql的Position值
5. 启动slave,执行如下命令:
start slave
- 查看slave状态:
show slave status
结果如下:
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 182.92.172.80
Master_User: rep1
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000013
Read_Master_Log_Pos: 11662
Relay_Log_File: mysqld-relay-bin.000022
Relay_Log_Pos: 11765
Relay_Master_Log_File: mysql-bin.000013
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
…
Slave_IO_Running 和 Slave_SQL_Running 都是Yes代表主从复制配置成功。
五、测试
在主mysql中插入表或者数据,看看从数据库会不会有数据同步过去,如果有,代表大功告成了。