Mysql主主数据库同步 及 问题处理

# mysql 主主

#技术

```

MySQL主主同步和主从同步的原理一样,只是双方都是主从角色。

网址:MySQL主主数据同步_mysql主主同步-CSDN博客

环境

操作系统版本:CentOS7 64位

MySQL版本:mysql5.6.33

节点1IP:192.168.1.205 主机名:edu-mysql-01

节点2IP:192.168.1.206 主机名:edu-mysql-02

MySQL 主从复制官方文档:MySQL :: MySQL 8.0 Reference Manual :: 17 Replication

注意:

1&gt 主从服务器操作系统版本和位数要保持一致

2&gt Master和Slave数据库的版本要一致

3&gt Master和Slave数据库中的数据要一致

配置

配置之前先参考《MySQL5.7安装与配置(YUM)》安装好MySQL(注意本文演示的是5.6版本,需要修改文章中的yum源为5.6)

1、安全配置

1&gt 防火墙

添加mysql通信端口(默认为3306)

shell&gt vim /etc/sysconfig/iptables

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

shell&gt service iptables restart

或关闭防火墙

shell&gt service iptables stop

2&gt 关闭selinux

shell&gt vi /etc/selinux/config

SELINUX=disabled

将SELINUX的值修改为disabled

2. 节点1配置(192.168.1.205)

2.1 添加数据同步配置

Shell&gt vim /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开始),单数

2.2 Master配置

# 先重启一下服务

shell&gt service mysqld restart

# 登录到mysql

shell&gt mysql -uroot -p

# 创建数据库同步用户,并授予相应的权限

mysql&gt grant replication slave, replication client on *.* to ‘root’@‘192.168.2.146’ identified by ‘pi’goss;

# 刷新授权表信息

mysql&gt flush privileges;

# 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到

mysql&gt 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.3 Slave配置

# master_user和master_password:在206上执行grant replication slave...创建的用户和密码

# master_log_file和master_log_pos:在206上运行show master status;命令执行结果对应File和Position字段的值

mysql&gt change master to master_host='192.168.2.145’,master_user='root',master_password='pigoss',master_port=3306,master_log_file='edu-mysql-bin.000001',master_log_pos=424,master_connect_retry=30;

# 查看作为从节点的状态信息

mysql&gt 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表示也没有运行。

2.4 启动Slave

注意:要在节点2上创建同步帐户后再启动,否则会报连不上master错误

# 启动从节点,开始工作接收主节点发送事件(数据库数据变更的所有事件)

mysql&gt start slave;

# 此时再查看slave节点的状态

mysql&gt show slave status\G;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

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:

# ...省略其它配置

3. 节点2配置(192.168.1.206)

3.1 添加数据同步配置

shell&gt vim /etc/my.cnf

1

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

server_id=206

binlog-ignore-db=mysql

log-bin=edu-mysql-bin

binlog_cache_size=1M

binlog_format=mixed

expire_logs_days=7

slave_skip_errors=1062

relay_log=edu-mysql-relay-bin

log_slave_updates=1

#ID自增从2开始,双数

auto_increment_increment=2

auto_increment_offset=2

3.2 Master配置

# 先重启一下服务

shell&gt service mysqld restart

# 登录到mysql

shell&gt mysql -uroot -p

# 创建数据库同步用户,并授予相应的权限(只允许repl用户从192.168.1.205上登录)

mysql&gt grant replication slave, replication client on *.* to 'repl'@'192.168.1.205' identified by 'root123456';

# 刷新授权表信息

mysql&gt flush privileges;

# 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到

mysql&gt show master status;

+----------------------+----------+--------------+------------------+-------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

+----------------------+----------+--------------+------------------+-------------------+

| edu-mysql-bin.000001 | 439 | | mysql | |

+----------------------+----------+--------------+------------------+-------------------+

1 row in set (0.00 sec)

这时可以启动节点1(205)的slave服务

3.3 Slave配置

# master_log_file和master_log_pos:205节点上执行show master status;对应File和position的值

mysql&gt change master to master_host='192.168.1.205',master_user='repl', master_password='root123456', master_port=3306, master_log_file='edu-mysql-bin.000001', master_log_pos=120, master_connect_retry=30;

Query OK, 0 rows affected, 2 warnings (0.02 sec)

mysql&gt show slave status\G;

*************************** 1. row ***************************

Slave_IO_State:

Master_Host: 192.168.1.205

Master_User: repl

Master_Port: 3306

Connect_Retry: 30

Master_Log_File: edu-mysql-bin.000001

Read_Master_Log_Pos: 120

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

Replicate_Do_DB:

#...省略其它配置

3.4、启动Slave

shell&gt start slave;

Query OK, 0 rows affected (0.01 sec)

mysql&gt show slave status\G;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.1.205

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:

...省略其它配置

# 登录205创建一个数据库

shell&gt mysql -u root -p

mysql&gt create database if not exists mydb default character set utf8 collate utf8_general_ci;

mysql&gt create table user (id int, username varchar(30), password varchar(30));

mysql&gt insert into user values (1, 'yangxin', '123456');

# 下面是在206节点上的操作

#1、登录206查询所有库,是否包含mydb数据库

#2、切换到mydb库,是否包含user表,并有一条数据

#3、在206的mydb.user表插入一条数据,查看205是否同步过去

mysql&gt insert into user values (2,'yangxin2','123456')

主从同步报错Last_IO_Error: error connecting to master 'lsx@192.XXXX' - retry-time: 60 retries: 86400解决办法。

网址:主从同步报错Last_IO_Error: error connecting to master ‘use@192.XXXX‘ - retry-time: 60 retries: 86400解决办法。-CSDN博客

1、从服务器报错先查看主服务器的my.cnf文件中的server-id = XX行的id是不是与从服务的server-id = XX相同,相同的随便改一个一般取ip的最后一段

2、在主服务器重新查询bin-log文件及 position点,要先给用户设置权限

mysql&gt GRANT REPLICATION SLAVE ON *.* to 'lsx'@'%' identified by '123';

Query OK, 0 rows affected (0.00 sec)

mysql&gt show master status;

+------------------+----------+--------------+------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| mysql-bin.000010 | 245 | | |

+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

lsx设置为你要设置的用户123为用户密码查询后就不要在操作主服务器了。

3、在从服务器先停止slave

mysql&gt slave stop; //停止slave

Query OK, 0 rows affected (0.01 sec)

mysql&gt change master to master_host='192.168.xxx',master_user='lsx',master_password='123',master_log_file='mysql-bin.000010',master_log_pos=245; //为slave指定 master IP、用户名、密码、 bin-log文件名( mysql-bin.000010)及position(245)

Query OK, 0 rows affected (0.01 sec)

mysql&gt slave start; //启动slave

Query OK, 0 rows affected (0.01 sec)

然后在从服务器上进行查询

mysql&gt show slave status\G

解决

mysql主从同步报错 Got fatal error 1236 from master when reading data from binary log

Slave: stop slave;

Master: flush logs

Master: show master status;

Slave: CHANGE MASTER TO MASTER_LOG_FILE=’log-bin.00000X’, MASTER_LOG_POS=106;

Slave: start slave;

```

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值