级联复制

所谓级联复制就是 master A 服务,只给一台 slave B 同步数据,然后 slave B 在向后端的所有slave 同步数据,降低 master 服务的写压力,和复制数据的网络IO。

mysql数据库级联操作 mysql 级联从库_java

这是一种非常好的扩展方式,在减少主库写压力与复制数据时IO的压力的同时,还能保证业务的正常开展。更多关于MySQL学习的文章,请参阅:死磕数据库系列之 MySQL ,本系列持续更新中。

接下来,就开始实践操作步骤。

master 配置


mysql数据库级联操作 mysql 级联从库_java_02

修改主配置文件
vim /etc/my.cnf

[mysql]配置块下添加如下两行配置

[mysql]
log_bin         #开启二进制日志功能
server_id=1     #为当前节点设置一个全局惟一的ID号
重启mysql服务,使配置生效
systemctl restart mysql
授权复制权限
grant replication slave  on *.* TO 'repluser'@'10.0.0.%' identified by 'replpass';

该命令作用就是授权repluser能拷贝数据库的所有内容。

参数解析
grant replcation slave:#就是允许该用户复制数据,授权repluser能拷贝数据库的所有内容
*.*:#表示所有数据库,所有表;
'repluser'@'10.0.0.%':#设置用户名即主机ip或网段,网段用%表示1~255;
identified by:#设置密码。

中继 slave 配置

修改主配置文件
vim /etc/my.cnf

[mysql]配置块中添加如下两行配置:

[mysqld]
log_bin
server_id=2        #为当前节点设置一个全局惟一的ID号 
read_only=ON       #限制从服务器为只读.``"注意:此限制对拥有SUPER权限的用户均无效"
log_slave_updates  #该项的作用是把master服务器的二进制日志计入到本机,然后再把二进制日志复制给后端的其他slave服务器
重启mysql服务,使配置生效
systemctl restart mysql
使用有复制权限的用户账号连接至主服务器,并启动复制线程
change master to 
master_host='10.0.0.1',                # 指定master主机IP
master_user='repluser',                # 指定master被授权的用户名
master_password='replpass',            #指定被授权的用户密码 
master_log_file='mysql-bin.xxxxx',     #指定从master服务器的那个二进制日志开始复制
master_log_pos=#;                      #二进制日志位置,可以在master服务器上执行该命令查看,show master logs;
启动复制线程 IO_thread 和 SQL_thread
start slave;
查看中继slave状态
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
 
mysql> show slave status \G ;
*************************** 1. row ***************************
                Slave_IO_State: Waiting for master to send event
                   Master_Host: 192.168.68.7
                   Master_User: repluser
                   Master_Port: 3306
                 Connect_Retry: 60
               Master_Log_File: mariadb-bin.000001
           Read_Master_Log_Pos: 557
                Relay_Log_File: mariadb-relay-bin.000002
                 Relay_Log_Pos: 843
         Relay_Master_Log_File: mariadb-bin.000001
              Slave_IO_Running: Yes "重点关注如果是NO表示线程没起来"
             Slave_SQL_Running: Yes "重点关注 如果是NO表示该线程没起来"
               Replicate_Do_DB: 
           Replicate_Ignore_DB: 
            Replicate_Do_Table: 
        Replicate_Ignore_Table: 
       Replicate_Wild_Do_Table: 
   Replicate_Wild_Ignore_Table: 
                    Last_Errno: 0
                    Last_Error: 
                  Skip_Counter: 0
           Exec_Master_Log_Pos: 557
               Relay_Log_Space: 1139
               Until_Condition: None
                Until_Log_File: 
                 Until_Log_Pos: 0
            Master_SSL_Allowed: No
            Master_SSL_CA_File: 
            Master_SSL_CA_Path: 
               Master_SSL_Cert: 
             Master_SSL_Cipher: 
                Master_SSL_Key: 
         Seconds_Behind_Master: 0 "该项表示同步时间 0表示即使同步"
 Master_SSL_Verify_Server_Cert: No
                 Last_IO_Errno: 0
                 Last_IO_Error: 
                Last_SQL_Errno: 0
                Last_SQL_Error: 
   Replicate_Ignore_Server_Ids: 
              Master_Server_Id: 1

后端 slave 配置

修改配置文件
vim /etc/my.cnf

[mysql]配置块中添加如下两行配置

[mysqld]  
server_id=3   #为当前节点设置一个全局惟一的ID号
read_only=ON #限制从服务器为只读."注意:此限制对拥有SUPER权限的用户均无效"
重启mysql服务,使配置生效
systemctl restart mysql
使用有复制权限的用户账号连接至主服务器,并启动复制线程
change master to 
master_host='中继host',     #指定中继slave主机IP
master_user='repluser',    #指定master被授权的用户名
master_password='replpass', #指定被授权的用户密码 MASTER_LOG_FILE='mysql-bin.xxxxx', #指定从中继slave服务器的那个二进制日志开始复制
master_log_pos=#;          #二进制日志位置,可以在slave服务器上执行该命令查看,show master logs;
启动复制线程IO_THREAD和SQL_THREAD
start slave;
查看slave状态
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
 
mysql> show slave status\G
*************************** 1. row ***************************
                  Slave_IO_State: Waiting for master to send event
                     Master_Host: 192.168.68.17
                     Master_User: repluser
                     Master_Port: 3306
                   Connect_Retry: 60
                 Master_Log_File: mariadb-bin.000001
             Read_Master_Log_Pos: 557
                  Relay_Log_File: mariadb-relay-bin.000002
                   Relay_Log_Pos: 843
           Relay_Master_Log_File: mariadb-bin.000001
                Slave_IO_Running: Yes "重点关注如果是NO表示线程没起来"
               Slave_SQL_Running: Yes "重点关注 如果是NO表示该线程没起来"
                 Replicate_Do_DB: 
             Replicate_Ignore_DB: 
              Replicate_Do_Table: 
          Replicate_Ignore_Table: 
         Replicate_Wild_Do_Table: 
     Replicate_Wild_Ignore_Table: 
                      Last_Errno: 0
                      Last_Error: 
                    Skip_Counter: 0
             Exec_Master_Log_Pos: 557
                 Relay_Log_Space: 1139
                 Until_Condition: None
                  Until_Log_File: 
                   Until_Log_Pos: 0
              Master_SSL_Allowed: No
              Master_SSL_CA_File: 
              Master_SSL_CA_Path: 
                 Master_SSL_Cert: 
               Master_SSL_Cipher: 
                  Master_SSL_Key: 
           Seconds_Behind_Master: 0 "该项表示同步时间 0表示即使同步"
   Master_SSL_Verify_Server_Cert: No
                   Last_IO_Errno: 0
                   Last_IO_Error: 
                  Last_SQL_Errno: 0
                  Last_SQL_Error: 
     Replicate_Ignore_Server_Ids: 
                Master_Server_Id: 1
最后在 master 上创建数据库测试即可查看是否同步

级联复制特点:

  • 降低master 服务压力,网络io压力
  • 但是会产生数据不一致的问题

总结

  • 中继slave需要打开二进制日志,必须加上 log_slave_updates 配置项
  • 注意read_only=ON作用,限制 中继slave 为只读。

注意:此限制对拥有 super 权限的用户均无效


双主双从

一个主机 master1 用于处理所有写请求, 它的从机 slave1 和另一台主机 master2 还有它的从机 slave2 负责所有读请求

当 master1 主机宕机后, master2 主机负责写请求, master1、 master2 互为备机。架构图如下 :

mysql数据库级联操作 mysql 级联从库_服务器_03

服务器规划


mysql数据库级联操作 mysql 级联从库_mysql_04

双 Master 机配置文件修改

说明 :当前所有的 mysql 是正常运行的单机版 ,下面的配置只是增加双主双从,不是mysql从零开始配置的。

Master1 配置
vim /etc/my.cnf

my.cnf 增加 的内容:

[mysqld]

#主服务器唯一ID (与 Master2,...... MasterN 的不同点)
server-id=1
#启用二进制日志
log-bin=mysql-bin

#从库的中继日志,主库日志写到中继日志,中继日志再重做到从库
# relay-log=myslql-relay-bin

# binlog保留时间7天
expire_logs_days=7

# binlog 文件的大小
max_binlog_size=1G

#设置logbin格式。取值:STATEMENT (默认),ROW,MIXED
binlog_format=ROW

# 该从库是否写入二进制日志。如果需要成为多主则可启用。只读可以不需要
log-slave-updates=1

# 该服务器自增列的初始值。(与 Master2,...... MasterN 的不同点)
auto-increment-offset=1

# 该服务器自增列增量。其默认值是1, 取值范围是1 .. 65535
auto-increment-increment=2

# 设置不要复制的数据库(可设置多个)
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=sys

#设置需要复制的数据库(可选)。
# 如果要配置了此项,则 mysql 只复制下面指定的数据库。
# 如果不配置此项,则 mysql 默认复制所有的数据库(不包含 binlog-ignore-db 的数据库)
binlog-do-db=需要复制的主数据库1
binlog-do-db=需要复制的主数据库2
Master2 配置

修改配置文件:

vim /etc/my.cnf

my.cnf 增加 的内容:

[mysqld]

#主服务器唯一ID。(与 Master1,Master3,...... MasterN 的不同点)
server-id=3
#启用二进制日志
log-bin=mysql-bin

#从库的中继日志,主库日志写到中继日志,中继日志再重做到从库
# relay-log=myslql-relay-bin

# binlog保留时间7天
expire_logs_days=7

# binlog 文件的大小
max_binlog_size=1G

#设置logbin格式。取值:STATEMENT (默认),ROW,MIXED
binlog_format=ROW

# 双主模式中,log-slave-updates必须配置。因为作为从数据库的时候,有写入操作也要更新二进制日志文件
log-slave-updates=1

# 该服务器自增列的初始值。取值范围是1 .. 65535
auto-increment-offset=2

# 该服务器自增列增量。(与 Master1,Master 3, ...... MasterN 的不同点)
auto-increment-increment=2

# 设置不要复制的数据库(可设置多个)
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=sys

#设置需要复制的数据库(可选)
# 如果要配置了此项,则 mysql 只复制下面指定的数据库。
# 如果不配置此项,则 mysql 默认复制所有的数据库(不包含 binlog-ignore-db 的数据库)
binlog-do-db=需要复制的主数据库1
binlog-do-db=需要复制的主数据库2
重启Mysql,使配置生效
systemctl restart mysqld.service

双 Slave 机配置文件修改

Slave1 配置
vim /etc/my.cnf

my.cnf 的内容:

[mysqld]

#从服务器唯一ID
server-id=2
#启用中继日志
relay-log=mysql-relay
Slave2 配置
vim /etc/my.cnf

my.cnf 的内容:

[mysqld]

#从服务器唯一ID
server-id=4
#启用中继日志
relay-log=mysql-relay
重启Mysql,使配置生效
systemctl restart mysqld.service

双 Master 机上创建账号,并授权远程复制

grant replication slave on *.* TO 'slave'@'%' identified by '123123';
查询Master1的状态
show master status;


mysql数据库级联操作 mysql 级联从库_mysql数据库级联操作_05

查询Master2的状态
show master status;

mysql数据库级联操作 mysql 级联从库_mysql_06

分别记录下 File 和 Position 的值,执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化。

双Slave机上执行 change master

change master 命令格式如下:

#复制主机的命令
change master to master_host='主机的IP地址',
master_user='slave',
master_password='123123',
master_log_file='mysql-bin.具体数字',
master_log_pos=154;
执行 change master 命令

Slave1 复制 Master1的命令:

mysql数据库级联操作 mysql 级联从库_mysql数据库级联操作_07

Slave2 复制 Master2的命令:

mysql数据库级联操作 mysql 级联从库_mysql数据库级联操作_08

启动两台Slave服务器复制功能
#启动两台从服务器复制功能
start slave;
查看Slave服务器状态

查看从服务器状态的命令:

show slave status\G;
Slave1 上 mysql 的从服务器状态


mysql数据库级联操作 mysql 级联从库_mysql_09

Slave2 上 mysql 的从服务器状态

mysql数据库级联操作 mysql 级联从库_mysql_10

Slave_IO_RunningSlave_SQL_Running 两个参数都是Yes,则说明主从配置成功!

从服务涉及到的命令:

1、停止从服务复制功能

stop slave;

2、重新配置主从 :

stop slave;
reset master;

两个主机互相复制 change master

因为是双主双从,所以要配置 Master2 复制 Master1, Master1 复制 Master2。

在 Master2 上执行 的命令

相当于Master2 作为 从机,复制主机 Master1 (101)上的数据。

mysql数据库级联操作 mysql 级联从库_mysql_11

change master to master_host='192.168.140.101',    ## Master1 的host IP
master_user='slave',
master_password='123123',
master_log_file='mysql-bin.000008',master_log_pos=154;  ## Master1 的mysql-bin 相应参数

在 Master1 上的执行命令:

相当于Master1 作为 从机,复制主机 Master2 (102)上的数据。

mysql数据库级联操作 mysql 级联从库_服务器_12

change master to master_host='192.168.140.102',  ## Master2 的host IP
master_user='slave',
master_password='123123',
master_log_file='mysql-bin.000001',master_log_pos=154;  ## Master2 的mysql-bin 相应参数
启动两台 Master 服务器复制功能
#在两个Mysql主服务上,执行复制功能
start slave;
查看两台 Master 服务的 Slave 服务器状态

从服务器状态命令:

show slave status\G;
Master2 的服务状态:


mysql数据库级联操作 mysql 级联从库_mysql数据库级联操作_13

Master1 的服务状态 :

mysql数据库级联操作 mysql 级联从库_mysql数据库级联操作_14

Slave_IO_RunningSlave_SQL_Running 两个参数都是Yes,则说明主从配置成功!

双主从双测试

在 Master1 主机新建库、新建表、 insert 记录,然后在 Master2、slave1、slave2上查看复制 是否成功。

mysql数据库级联操作 mysql 级联从库_数据库_15