mysql主从复制(基于binary log file;centos系统下)

一、导读

最近学习,mysql的读写分离技术,这篇文章是读写分离的基础,今天就给大家一起来搭建一个主从复制的mysql。

二、准备环境

  1. 准备2个版本一致的mysql数据库 (我的是centos系统装的2个mysql,一个宿主机上的mysql,一个是docker的mysql)
  2. 实现MySQL主从复制需要进行的配置:
  • 主服务器:
    1. 开启二进制日志
    2. 配置唯一的server-id
  • 从服务器:
    1. 配置唯一的server-id
    2. 使用master分配的用户账号读取master二进制日志
    3. 启用slave服务

三、配置主mysql

  1. 修改mysql配置
    找到主数据库的配置文件my.cnf,我的在/etc/mysql/my.cnf,插入如下两行

log-bin=mysql-bin #开启二进制日志
server-id=1 #设置server-id

  1. 重启mysql
  2. 查看主mysql的状态,使用如下命令查询,记住File 和 Position 两个值。

SHOW MASTER STATUS;

结果如下:

File Position
mysql-bin.000005 3895

四、配置从mysql

  1. 同样找到my.cnf配置文件,里面添加server-id

server-id=2 #设置server-id,必须和上面的主mysql的id不一样,唯一

  1. 重启mysql
  2. 停止slave
    用户登录,执行如下命令:

stop slave

  1. 执行同步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

  1. 查看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中插入表或者数据,看看从数据库会不会有数据同步过去,如果有,代表大功告成了。

猜你喜欢

转载自blog.csdn.net/qq_37054881/article/details/90640899
今日推荐