MySQL主主数据同步

环境

操作系统版本:CentOS7 64位
MySQL版本:mysql5.6.39
节点1IP:192.168.1.205
节点2IP:192.168.1.206
MySQL 主从复制官方文档:http://dev.mysql.com/doc/refman/5.6/en/replication.html

注意:
1> 主从服务器操作系统版本和位数要保持一致
2> Master和Slave数据库的版本要一致
3> Master和Slave数据库中的数据要一致
4>防火墙要关闭(或开放权限端口)

配置
1.Master节点配置,主机1和主机2都配置(server_id要唯一)

执行 vi /etc/my.cnf  

在[mysqld]中增加以下配置项:

# 服务器的ID,必须唯一,一般设置自己的IP
server_id=205
# 复制过滤:不需要备份的数据库(MySQL库一般不同步)
binlog-ignore-db=mysql
# 开启二进制日志功能,名字可以随便取,最好有含义(比如项目名)
log-bin=edu-mysql-bin
# 为每个 session 分配的内存,在事务过程中用来存储二进制日志的缓存
binlog_cache_size=1M
# 主从复制的格式(mixed,statement,row,默认格式是 statement)
binlog_format=mixed
# 二进制日志自动删除/过期的天数。默认值为 0,表示不自动删除。
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免 slave 端复制中断。 
## 如:1062 错误是指一些主键重复,1032 错误是因为主从数据库数据不一致
slave_skip_errors=1062
# 作为从服务器时的中继日志
relay_log=edu-mysql-relay-bin
# log_slave_updates 表示 slave 将复制事件写进自己的二进制日志
log_slave_updates=1
# 主键自增规则,避免主从同步ID重复的问题
auto_increment_increment=2  # 自增因子(每次加2)
auto_increment_offset=1     # 自增偏移(从1开始),单数

配置完后

# 先重启一下服务
service mysqld restart  
# 登录到mysql
mysql -uroot -p 
# 创建数据库同步用户,并授予相应的权限(192.168.1.206 为另一台机的ip地址)
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.206' identified by 'root123456';
# 刷新授权表信息
mysql> flush privileges;
# 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到
mysql> show master status; +----------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +----------------------+----------+--------------+------------------+-------------------+
| edu-mysql-bin.000001 | 120 | | mysql | | +----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

2.Slave配置,主机1和主机2都配置

mysql> change master to master_host='192.168.1.206',master_user='repl', master_password='root123456', master_port=3306, master_log_file='edu-mysql-bin.000001', master_log_pos=439, master_connect_retry=30;
# master_user和master_password:在另一台机上grant replication slave...创建的用户和密码
# master_log_file和master_log_pos:在另一台机上运行show master status;命令执行结果对应File和Position字段的值
# 查看作为从节点的状态信息
mysql> show slave status\G;
*************************** 1. row ***************************
 Slave_IO_State:
 Master_Host: 192.168.1.206
 Master_User: repl
 Master_Port: 3306
 Connect_Retry: 30
 Master_Log_File: edu-mysql-bin.000001
 Read_Master_Log_Pos: 439
 Relay_Log_File: edu-mysql-relay-bin.000001
 Relay_Log_Pos: 4
 Relay_Master_Log_File: edu-mysql-bin.000001
 Slave_IO_Running: No
 Slave_SQL_Running: No
 # 省略其它配置。。。

# 由于此时从节点还没有启动,Slave_IO_State的值为空,Slave_IO_Running和Slave_SQL_Running线程为No表示也没有运行。启动从节点,开始工作接收主节点发送事件(数据库数据变更的所有事件)
mysql> start slave;
# 此时再查看slave节点的状态
mysql> show slave status\G;
*************************** 1. row ***************************
 Slave_IO_State: Waiting for master to send event(或提示已经连接master)
 Master_Host: 192.168.1.206
 Master_User: repl
 Master_Port: 3306
 Connect_Retry: 30
 Master_Log_File: edu-mysql-bin.000001
 Read_Master_Log_Pos: 439
 Relay_Log_File: edu-mysql-relay-bin.000002
 Relay_Log_Pos: 287
 Relay_Master_Log_File: edu-mysql-bin.000001
 Slave_IO_Running: Yes
 Slave_SQL_Running: Yes
 Replicate_Do_DB:
 # ...省略其它配置

最后测试。
文章来源参考

你可能感兴趣的:(linux)