MySQL实现配置主从复制项目实践

作者:BugMaker-shen 时间:2024-01-15 16:54:20 

一、检测通信

查看master(centos7)和slave(win10)的ip地址,并检测是否可以相互通信

MySQL实现配置主从复制项目实践

MySQL实现配置主从复制项目实践

MySQL实现配置主从复制项目实践

MySQL实现配置主从复制项目实践

到这里我们知道,master的ip为192.168.131.129,slave的ip为192.168.0.6,并且可以相互通信

查看防火墙状态

systemctl status firewalld.service

临时手动启动、停止防火墙

systemctl start firewalld.service
systemctl stop firewalld.service

持久打开、关闭防火墙(重启服务生效)

systemctl enable firewalld.service
systemctl disable firewalld.service

MySQL实现配置主从复制项目实践

开放3306端口

MySQL实现配置主从复制项目实践

二、master配置

1. 开启二进制日志

配置log_bin和全局唯一的server-id,和slave区分开,不能配置成一样的(如果是my.cnf新添加配置,一定要重启MySQL服务)

MySQL实现配置主从复制项目实践

2. 创建一个用于主从库通信用的账号

即在master中创建一个账号,用于slave登录master读取binlog

虽然我们在Linux上查看的ip地址是192.168.131.129,但我们创建账户登录时不写这个ip,写的是192.168.131.1。因为我这里虚拟机用的是NAT模式,虚拟机(master)和物理机(slave)通信的时候,虚拟机先把数据发送到网关192.168.131.1(默认与VMnet8通信),192.168.131.1再转发到物理机,所以物理机接收到的是192.168.131.1的数据,故我们在master上为slave创建账户的时候,应该写192.168.131.1

MySQL实现配置主从复制项目实践

如果给slave配置的不是网关192.168.131.1地址,错误日志(可在my.cnf中指定)中会有如下信息:

MySQL实现配置主从复制项目实践

意思是从192.168.131.1的mslave用户权限不够,那是因为我们在master上配置的是允许从其他地址登录,并不是允许从192.168.131.1地址登录,这就导致权限不够。

由于master这边收到的就是来自192.168.131.1的请求,所以错误日志显示的是192.168.131.1

所以创建账户的命令应如下:

mysql> CREATE USER 'mslave'@'192.168.131.1' IDENTIFIED BY '1qaz@WSX';
mysql> GRANT REPLICATION SLAVE ON *.* to 'mslave'@'192.168.131.1' IDENTIFIED BY '1qaz@WSX';
mysql> FLUSH PRIVILEGES;

开启主从复制的权限,从库可以通过这个账户和密码,从这个IP来请求访问这个主库上的任意库,同步这个主库的任意库里的任意表

3. 获取binlog文件名和position

看当前二进制日志的名字,主库的更新是往哪个binlog写的,以及当前写日志的位置,从这个位置往后开始进行主从同步

show master status;

MySQL实现配置主从复制项目实践

三、slave配置

1. 配置全局唯一的server-id

找到my.ini

MySQL实现配置主从复制项目实践

配置全局唯一的server-id

MySQL实现配置主从复制项目实践

重启MySQL服务

MySQL实现配置主从复制项目实践

2. 使用master创建的账户读取binlog同步数据

这一步配置主要是给IO线程读取binlog使用

mysql> CHANGE MASTER TO MASTER_HOST='192.168.131.129',MASTER_PORT=3306,MASTER_USER='mslave',MASTER_PASSWORD='1qaz@WSX',
MASTER_LOG_FILE='mysql-bin.000006',MASTER_LOG_POS=1262;

MASTER_HOST:指定master的ip
MASTER_LOG_FILE:binlog文件名
MASTER_LOG_POS:binlog的position

3. 开启slave服务

通过show slave status命令查看主从复制状态,show processlist查看master和salve相关线程的运行状态

MySQL实现配置主从复制项目实践

四、配置中可能出现的问题

1. 网络连接问题

通过show slave status命令查看主从复制状态

MySQL实现配置主从复制项目实践

连接connection错误,先考虑是否网络互通,ping一下

然后再检查从库里面的配置信息是否正确

MySQL实现配置主从复制项目实践

如果都正确,还可以检查一下master的3306端口是否可以连接

telnet xxx.xxx.xxx.xxx 3306

最重要的是,自己玩的时候,如果虚拟机是NAT模式,则需要写成VMnet8网关ip。如果都是物理机通信,那直接写正确的ip即可

可以在MySQL数据库下的mysql库的user表中更改允许登录的ip

MySQL实现配置主从复制项目实践

然后重新赋予权限

mysql> GRANT REPLICATION SLAVE ON *.* to 'mslave'@'xxx.xxx.xxx.xxx' IDENTIFIED BY '1qaz@WSX';

出现错误后还可以查看错误日志中提示的ip是否和自己允许slave登录的ip一致

MySQL实现配置主从复制项目实践

2. binlog的position问题

MySQL实现配置主从复制项目实践

在master中查看show master status一下binlog日志文件名以及position,然后用命令重新配置slave,比如:

mysql> CHANGE MASTER TO MASTER_HOST='192.168.131.129',MASTER_PORT=3306,MASTER_USER='mslave',MASTER_PASSWORD='1qaz@WSX',
MASTER_LOG_FILE='mysql-bin.000006',MASTER_LOG_POS=1262;

配置slave前需要stop slave,配置完成再start slave

3. SQL线程出错

问题发生原因如下:

首先配置主从复制的时候,slave的mytest库中没有user表,而master的mytest库已经有user表了

配置好主从复制后直接drop table mytest.user,这就会写到binlog里面,然后在通过dump线程和IO线程将这个操作发送到从库的relay log,然后从库的SQL线程从relay log里把drop table mytest.user捞出来在从库执行这个SQL,可从库的mytest根本就没有user表,这就是删除一个不存在的表,于是出现错误了

MySQL实现配置主从复制项目实践

一般我们不会做这样的操作,一般都是主从配置以后,slave从数据开始增量进行同步,先做数据的增量,然后做数据的增删改查

不会配置好主从复制后,一开始就删主库的东西,如果真的出现这样的问题,随时可以在从库 show slave status,来查看主从同步的状态,有什么错误,就相应解决

要么在stop slave,把position重新设置一下,start slave,即重新开启主从同步,从最新的位置,这个drop操作不需要在从库上同步

要么就是stop,跳过该个错误,然后start

stop slave;
set global sql_slave_skip_counter=1;
start slave;

可以通过show slave status查看以下标识,IO线程出错一般是网络问题,SQL线程出错一般是SQL在slave库执行出现了问题

MySQL实现配置主从复制项目实践

来源:https://blog.csdn.net/qq_42500831/article/details/123849562

标签:MySQL,主从复制
0
投稿

猜你喜欢

  • vue使用v-for实现hover点击效果

    2024-05-02 17:09:03
  • OpenCV图像缩放之cv.resize()函数详解

    2021-02-06 12:36:58
  • 很快大多数网民将放弃IE浏览器

    2009-02-04 16:43:00
  • 利用ASP.NET MVC和Bootstrap快速搭建响应式个人博客站(一)

    2023-07-06 23:47:39
  • 深入分析PHP引用(&)

    2023-11-23 00:42:35
  • Python与Appium实现手机APP自动化测试的示例代码

    2023-07-26 05:06:07
  • Websocket IM聊天教程 教你用GoEasy快速实现IM聊天

    2023-10-04 08:52:52
  • asp按关键字查询XML的代码

    2011-04-21 11:10:00
  • Python局部变量与全局变量区别原理解析

    2021-06-18 01:50:05
  • Django基础之Model操作步骤(介绍)

    2022-04-12 12:17:50
  • AI:如何训练机器学习的模型

    2023-01-16 13:18:49
  • 如何连续展示数据库里的图片?

    2010-01-01 15:50:00
  • 推荐一篇不错的新手asp编程的基本法则

    2011-04-15 11:08:00
  • Python 在字符串中加入变量的实例讲解

    2023-01-27 10:51:21
  • Python调用C# Com dll组件实战教程

    2023-09-05 10:46:06
  • Python大批量搜索引擎图像爬虫工具详解

    2021-09-15 15:30:02
  • python 提高开发效率的5个小技巧

    2022-05-11 00:55:09
  • Python实现桌面翻译工具【新手必学】

    2021-03-27 08:32:47
  • 基于MATLAB和Python实现MFCC特征参数提取

    2023-01-29 07:37:53
  • MySQL实现分布式锁

    2024-01-25 19:31:03
  • asp之家 网络编程 m.aspxhome.com