msyql5.7版本linux版主从复制配置详解

共同学习,共同进步

主从数据库配置

1.操作步骤

1)开启master的二进制日志

2)开启slave的二进制日志

3)将slave指向master

4)开始复制

2.开启master二进制日志

1)编辑mysql配置文件

1 [root@VM_0_10_centos ~]# vi /etc/my.cnf

2)添加二进制日志配置,开启二进制(mysql-bin只是二进制日志名称,可以自行指定)

1 server-id=1    	#id是一定要指定的,是唯一的标识(master数据库要比slave数据库的id优先级高才行)
2 log-bin=mysql-bin  =#开启二进制日志

3)授权

登录数据库

需要给slave数据库配置一个用户/密码的权限

1 mysql> grant replication slave on *.* to 'root'@'slave数据库ip' identified by '密码';

允许某个ip地址的某个用户以某个密码对当前数据库的所有库和表进行复制操作

配置之后需要刷新权限

1 mysql> flush privileges;

上面修改配置文件需重启服务

1 [root@VM_0_10_centos ~]# systemctl restart mysqld

4)查看master的状态

登录数据库

1 mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000004 |      154 | school       | mysql            |                   |
+------------------+----------+--------------+------------------+-------------------+

file:是日志文件名称

position:日志所在位置,从哪个位置开始复制

3.开启slave的二进制日志

登录slave服务器

1)配置my.cnf配置文件

1 [root@VM_0_16_centos ~]# vi /etc/my.cnf

2)添加slave二进制日志配置,开启二进制(mysql-bin只是二进制日志名称,可以自行指定)

1 server-id=2
2 log-bin=mysql-bin

注意:每一台指定唯一的一个server-id标识

修改完配置服务需重启服务

1 [root@VM_0_16_centos ~]# systemctl restart mysqld

3)配置slave指向master

登录数据库

1 mysql> change master to
2     -> master_host='master数据库ip',
3     -> master_user='master授权账号',
4     -> master_password='授权密码',
5     -> master_log_file='master日志文件(mysql-bin.000001)',
6     -> master_log_pos=master日志所在位置(154);
#案列
mysql> change master to master_host='192.168.237.102',
    -> master_user='root',
    -> master_password='12345678',
    -> master_log_file='mysql-bin.000004',
    -> master_log_pos=154;
Query OK, 0 rows affected, 2 warnings (0.02 sec)

master的日志文件名称可以在master数据库使用show master status查看到。最好在每次授权之前,使用

show master status查看master_log_file和master_log_pos参数。

注意事项

mysql> change master to master_host='192.168.237.102',
    -> master_user='root',
    -> master_password='12345678',
    -> master_log_file='mysql-bin.000004',
    -> master_log_pos=154;
ERROR 3021 (HY000): This operation cannot be performed with a running slave io thread; run STOP SLAVE IO_THREAD FOR CHANNEL '' first.

如果出现上面的错误则需要先执行以下命令,在执行change master to。。。命令。

mysql> stop slave;

4.开启主从复制

在slave服务器上执行

1 mysql> start slave;

查看slave运行状态

1 mysql> show slave status\G;

​ *:\G表示分行显示

可看到如下内容

mysql> show slave status\G;

#主要参数
*************************** 1. row ***************************
            Slave_IO_State: Waiting for master to send event 
            Master_Log_File: mysql-bin.000001
            Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
1 row in set (0.00 sec)

ERROR:
No query specified

能查看到这两个为yes则成功

1 Slave_IO_Running: Yes     #表示slave的日志读取线程开启
2 Slave_SQL_Running: Yes    #表示SQL执行线程开启

5.测试主从复制

在master数据库创建表

mysql> create table `dog`(
    -> id int(11),
    -> name varchar(20))engine=innodb;
Query OK, 0 rows affected (0.03 sec)
mysql> insert into dog(id,name)values(1,'zhang');
Query OK, 1 row affected (0.02 sec)

登录从数据库查看

mysql> show tables;
+------------------+
| Tables_in_school |
+------------------+
| dog              |
| score            |
| student          |
| test_innodb_lock |
+------------------+
4 rows in set (0.01 sec)

mysql> select * from dog;
Empty set (0.00 sec)

mysql> select * from dog;
+------+-------+
| id   | name  |
+------+-------+
|    1 | zhang |
+------+-------+
1 row in set (0.00 sec)

如果出现不同步情况参考网址:https://blog.csdn.net/heng_ji/article/details/51013710
参考来源:https://www.cnblogs.com/HeiDi-BoKe/p/11390490.html

上一篇:redis哨兵模式(一主两从三哨兵模式搭建)


下一篇:MHA(MasterHigh Availability)高可用配置及故障切换