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的时候就回报错,错误信息如下:
[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)同步配置详解
-
基于MySQL Master Slave同步配置的操作详解
-
基于MySQL Master Slave同步配置的操作详解
-
mysql(master/slave)主从复制原理及配置图文详解
-
mysql(master/slave)主从复制原理及配置图文详解
-
基于MySQL Master Slave同步配置的操作详解_MySQL
-
MySQL5.6 数据库主从(Master/Slave)同步安装与配置详解
-
master/slave主从数据库手动同步之master-data_MySQL
-
MySQL5.6 数据库主从同步安装与配置详解(Master/Slave)
-
MySQL5.6 数据库主从同步安装与配置详解(Master/Slave)