欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2024-03-20 23:53:58
...

安装环境

操作系统 :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的时候就回报错,错误信息如下:
[aaa@qq.com_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)同步配置详解