MySQL5.6 数据库主从服务器配置

安装环境

操作系统:CentOS 6.8
数据库版本:MySQL 5.6
主机A:192.168.0.139 (Master)
主机B:192.168.0.108 (Slave)

环境配置

service iptables stop  #关闭防火墙 或者开启3306端口
setenforce 0  #关闭selinux

Master主机配置

vi /etc/my.cnf  #配置文件,在[mysqld]里面添加内容

log-bin=mysql-bin
server-id=2     #服务ID唯一,
binlog-ignore-db=mysql  #设置不需要同步的数据库
binlog-ignore-db=information_schema  #设置不需要同步的数据库
binlog-do-db=school     #设置需要同步的数据库名

#重启数据库库
service mysqld restart
mysql -u root -p  #进入mysql
mysql> grant replication slave on *.* to 'mysync'@'%' identified by '12345678';
# 创建mysync权限用户,密码12345678 添加replication slave权限
# *.* 表示所有数据库所有表,% 表示任意主机

#显示主服务器状态
mysql> show master status;

+------------------+----------+--------------+----------------------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB                 | Executed_Gtid_Set |
+------------------+----------+--------------+----------------------------------+-------------------+
| mysql-bin.000004 |      120 | school       | information_schema,cluster,mysql |                   |
+------------------+----------+--------------+----------------------------------+-------------------+
1 row in set (0.00 sec)

# 记录 File 的值 mysql-bin.000004,Position 的值 120;从服务器需要用到 

Slave主机配置

vi /etc/my.cnf  #配置文件,在[mysqld]里面添加内容

log-bin=mysql-bin
server-id=3    #服务ID唯一
replicate-do-db=school     #设置需要同步的数据库名
replicate-ignore-db=mysql  #设置不需要同步的数据库
replicate-ignore-db=information_schema  #设置不需要同步的数据库
log-slave-updates=1
#启用从机服务器上的slave日志功能,使这台计算机可以用来构成一个镜像链(A->B->C)
#可以让从库上面产生二进制日志文件,在从库上再挂载一个从库

#重启数据库库
service mysqld restart  
mysql -u root -p  #进入mysql

mysql> change master to
     > master_host='192.168.0.139',master_user='mysync',master_password='12345678',
     > master_port=3306,master_log_file='mysql-bin.000001',master_log_pos=120;

#在从服务器配置需要同步的主服务器 主机IP,用户名,密码,端口号,binlog文件binlog位置等信息

mysql> start slave;   #启动slave
mysql> show slave status\G  #查看从服务器配置信息
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.0.139  #主服务器IP
                  Master_User: mysync         #主服务器用户
                  Master_Port: 3306           
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000004   #主库上的二进制文件名
          Read_Master_Log_Pos: 120      #从库的IO进程,读取主库上的二进制日志的位置
               Relay_Log_File: mysqld-relay-bin.000009   #中继日志二进制文件名
                Relay_Log_Pos: 283      #从库的sql进程,读取从库上的中继日志的位置
        Relay_Master_Log_File: mysql-bin.000004
             Slave_IO_Running: Yes   #必须为yes
            Slave_SQL_Running: Yes   #必须为yes
              Replicate_Do_DB: school  #同步的数据库
          Replicate_Ignore_DB: mysql
           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: 120   #从库的sql线程执行到的位置,相对于主库
              Relay_Log_Space: 820
              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
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: 2
                  Master_UUID: 538c5e58-8cb6-11e9-b86a-080027972ea7
             Master_Info_File: /var/lib/mysql/master.info #此文件告诉主库下次重哪里开始读取
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: 
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

#上述信息 Slave_IO_Running: Yes,Slave_SQL_Running: Yes 表示同步成功

需要注意的是!!! 
线上的项目导出数据的时候,保证主库上锁,等slave导入、start slave之后在解锁; 
slave重启的时候也一样,重启之前,主库上锁,重启完毕,解锁;

flush tables with read lock  #锁表
unlock tables  #解锁

清除日志

purge master logs to 'mysql-bin.000003';   #清除mysql-bin.000003以前的日志

刷新日志

flush logs   #自此刻开始产生一个新编号的binlog日志文件

主重跳过错误

stop slave;
set global sql_slave_skip_counter=1;
start slave;

MySQL 主主同步注意事项

原理与主从同步一样,(既是主又是从,既是从又是主)配置相关参数,额外增加 以下

server-1(IP:192.168.0.139)
relay-log=relay-mysql                #启用中继日志
relay-log-index=relay-mysql.index    #中继日志索引
auto-increment-increment=2          #步进值auto_imcrement 一般有n台主MySQL就填n
auto-increment-offset=1             #起始值,一般填第n台主MySQL,此时为第1台主MySQL

server-2(IP:192.168.0.108)
relay-log=relay-mysql
relay-log-index=relay-mysql.index
auto-increment-increment=2
auto-increment-offset=2             #此时为第2台主MySQL

1、在两台服务器上互相创建具有复制权限的用户 grant replication slave on.... 以及配置 change master to……

2、两台机器分别运行 statr slave,显示YES,就可以同步成功

你可能感兴趣的:(mysql)