安装环境

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

环境配置

service iptables stop 
setenforce 0

Master主机配置

vim /etc/my.cnf

log-bin=mysql-bin # 启动binlog,必须要启用
server-id=2 # 服务ID唯一,
binlog-ignore-db=mysql # 设置不需要同步的数据库
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
binlog-ignore-db=sys

binlog-do-db=school

# 重启数据库库
service mysqld restart
mysql -u root -p
mysql> grant replication slave on *.* to 'mysync'@'%' identified by 'Mysync@123';
# 创建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主机配置

vim /etc/my.cnf

log-bin=mysql-bin # 从库binlog可以不启用
server-id=3 # 服务ID唯一
replicate-do-db=school # 设置需要同步的数据库名
replicate-ignore-db=mysql
replicate-ignore-db=information_schema
replicate-ignore-db=performance_schema
replicate-ignore-db=sys

log-slave-updates=1 # 启用从机服务器上的slave日志功能,使这台计算机可以用来构成一个镜像链(A->B->C),可以让从库上面产生二进制日志文件,在从库上再挂载一个从库

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

mysql> change master to
> master_host='192.168.0.139',master_user='mysync',master_password='Mysync@123',
> 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 表示同步成功

设置不同步的表

replicate-ignore-table=db_name.tbl_name

需要注意的是!!! 
线上的项目导出数据的时候,保证主库上锁,等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,就可以同步成功

设置不需要同步的表

replicate-ignore-table=school.tables名

设置只同步哪些表

replicate_do_table=school.tables名

或通配符
replicate_wild_do_table=sch%.stu%

 如果主从数据库不同名

replicate-rewrite-db = school -> 从库数据库名