MySQL5.6 数据库主从(Master/Slave)同步配置详解

安装环境

操作系统 :CentOS 7.5
数据库版本:MySQL 5.7.22
主机A:222.222.0.61 (Master)
主机B:222.222.0.62 (Slave)

基本环境配置

开放数据库端口
确保两台机器在同一个局域网

Master的配置

在Linux环境下MySQL的配置文件的位置是在 /etc/my.cnf ,在该文件下[mysqld]中指定Master的配置如下:

    log-bin=mysql-bin
    server-id=61
    binlog-ignore-db=information_schema
    binlog-ignore-db=mysql
    binlog-do-db=mstest

server-id:用于标识唯一的数据库,这里设置为61(与我自己的IP后面一段相同),在设置从库的时候就需要设置为其他值。
binlog-ignore-db:表示同步的时候ignore的数据库
binlog-do-db:指定需要同步的数据库
修改了配置文件重启MYSQL服务

进入mysql控制台:mysql -u root -p 回车,输入mysql密码进入
赋予从库权限帐号,允许用户在主库上读取日志,赋予222.222.0.62也就是Slave机器有File权限,只赋予Slave机器有File权限还不行,还要给它REPLICATION SLAVE的权限才可以。
在Master数据库命令行中输入:

CREATE USER 'repl'@'222.222.0.%' IDENTIFIED BY 'repl';
GRANT REPLICATION SLAVE ON *.* TO 'root'@'222.222.0.%' IDENTIFIED BY 'repl';
FLUSH PRIVILEGES;

这里使用的是 repl用户作为同步的时候使用到的用户,可以自己设定。

重启mysql,登录mysql,显示主库信息
show master status;

mysql>show master status;
+------------------+----------+--------------+--------------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB         | Executed_Gtid_Set |
+------------------+----------+--------------+--------------------------+-------------------+
| mysql-bin.000005 |     5772 | mstest       | information_schema,mysql |                   |
+------------------+----------+--------------+--------------------------+-------------------+
1 row in set (0.00 sec)

mysql>

这里的 File 、Position是在配置Salve的时候要使用到的,Binlog_Do_DB表示要同步的数据库,Binlog_Ignore_DB表示Ignore的数据库,这些都是在配置的时候进行指定的。
注:如果执行这个步骤始终为Empty set(0.00 sec),那说明前面的my.cnf没配置对。

Slave的配置

1.从库的配置,也是修改配置文件:/etc/my.cnf 如下:

log-bin=mysql-bin
server-id=62
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
replicate-do-db=mstest
replicate-ignore-db=mysql
log-slave-updates
slave-skip-errors=all
slave-net-timeout=60

2.这里可以看到,在MySQL5.6之后的版本中没有指定:

master-host=222.222.0.61 #Master的主机IP
master-user=root
master-password=mysql password #Master的MySQL密码

如果,你在MySQL5.6和之后的版本中配置从库的时候,设置到了上边的内容,即指定了master-host、master-user等信息的话,重启MySQL的时候就回报错,错误信息如下:
[root@mysql_2 ~]# service mysql restart
Shutting down MySQL.... SUCCESS!
Starting MySQL... ERROR! The server quit without updating PID file (/data/mysql/mysql_2.pid).


此时,查看数据库的报错信息(数据库的目录, /data/mysql/mysql_2.err)(可能不一样,根据情况来),可以看到:
[ERROR] unknown variable 'master-host=222.222.0.62'
可以看出master-host 被检测数是一个未知的变量,因此会出现错误。


修改my.cnf,删除master-host等配置之后重启一下MySQL(service mysql restart)

进入Slave mysql控制台,执行:

stop slave;  #关闭Slave

change master to 
master_host='222.222.0.61',
master_password='root',
master_log_file='mysql-bin.000005', 
master_log_pos=5772;

start slave;  #开启Slave

#show master status;命令查看到的master mysql上的信息对应写入
#在这里指定Master的信息,
#master_log_file是在配置Master的时候的File选项
#master_log_pos是在配置Master的Position 选项,这里要进行对应。

然后可以通过mysql> show slave status 查看配置的信息:
mysql>  show slave status \G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 222.222.0.61
                  Master_User: repl
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000005
          Read_Master_Log_Pos: 5772
               Relay_Log_File: mysql_2-relay-bin.000002
                Relay_Log_Pos: 2299
        Relay_Master_Log_File: mysql-bin.000005
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: mstest
          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: 5772
              Relay_Log_Space: 2508
              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: 1
                  Master_UUID: f7a686bf-666d-11e8-802c-000c294df5c9
             Master_Info_File: /data/mysql/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
           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
         Replicate_Rewrite_DB:
                 Channel_Name:
           Master_TLS_Version:
1 row in set (0.00 sec)

出现下面内容表示成功了:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

可以看到,已经配置成功。
MySQL5.6 数据库主从(Master/Slave)同步配置详解_第1张图片

你可能感兴趣的:(Linux)