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


Posted in MySQL onMarch 31, 2022

一、检测通信

查看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实现配置主从复制项目实践

 到此这篇关于MySQL实现配置主从复制项目实践的文章就介绍到这了,更多相关MySQL  主从复制内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
Windows10下安装MySQL8
Apr 06 MySQL
mysql的MVCC多版本并发控制的实现
Apr 14 MySQL
详解mysql三值逻辑与NULL
May 19 MySQL
zabbix监控mysql的实例方法
Jun 02 MySQL
你知道哪几种MYSQL的连接查询
Jun 03 MySQL
解决mysql:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO/YES)
Jun 26 MySQL
MySQL配置主从服务器(一主多从)
Aug 07 MySQL
MySQL如何解决幻读问题
Aug 07 MySQL
MySQL数据库必备之条件查询语句
Oct 15 MySQL
将MySQL的表数据全量导入clichhouse库中
Mar 21 MySQL
MySQL的表级锁,行级锁,排它锁和共享锁
Jul 15 MySQL
MySQL自定义函数及触发器
Aug 05 MySQL
Mysql多层子查询示例代码(收藏夹案例)
Mar 31 #MySQL
MySQL Server层四个日志的实现
分享几个简单MySQL优化小妙招
MySQL Server 层四个日志
MySQL RC事务隔离的实现
mysql中DCL常用的用户和权限控制
Mar 31 #MySQL
Mysql分析设计表主键为何不用uuid
You might like
PHP定时执行计划任务的多种方法小结
2011/12/19 PHP
PHP中session变量的销毁
2014/02/27 PHP
php定义数组和使用示例(php数组的定义方法)
2014/03/29 PHP
ThinkPHP空模块和空操作详解
2014/06/30 PHP
PHP面向对象程序设计之类常量用法实例
2014/08/20 PHP
给WordPress的编辑后台添加提示框的代码实例分享
2015/12/25 PHP
php事务回滚简单实现方法示例
2017/03/28 PHP
用JavaScript显示随机图像或引用
2009/04/21 Javascript
关于jQuery中的end()使用方法
2011/07/10 Javascript
js有关元素内容操作小结
2011/12/20 Javascript
javaScript让文本框内的最后一个文字的后面获得焦点实现代码
2013/01/06 Javascript
Javascript中string转date示例代码
2013/11/01 Javascript
jQuery取得select选择的文本与值的示例
2013/12/09 Javascript
Javascript的闭包详解
2014/12/26 Javascript
jQuery实现tab选项卡效果的方法
2015/07/08 Javascript
jquery实现LED广告牌旋转系统图片切换效果代码分享
2015/08/26 Javascript
jQuery.extend 函数及用法详细
2015/09/06 Javascript
BootStrap 智能表单实战系列(二)BootStrap支持的类型简介
2016/06/13 Javascript
JS实现中英文混合文字溢出友好截取功能
2018/08/06 Javascript
VUE+Element环境搭建与安装的方法步骤
2019/01/24 Javascript
利用JS响应式修改vue实现页面的input值
2019/09/02 Javascript
React实现类似淘宝tab居中切换效果的示例代码
2020/06/02 Javascript
解决VUE 在IE下出现ReferenceError: Promise未定义的问题
2020/11/07 Javascript
javascript this指向相关问题及改变方法
2020/11/19 Javascript
Python下的Mysql模块MySQLdb安装详解
2014/04/09 Python
Google开源的Python格式化工具YAPF的安装和使用教程
2016/05/31 Python
使用Python实现简单的服务器功能
2017/08/25 Python
JS设计模式之责任链模式实例详解
2018/02/03 Python
Python判断有效的数独算法示例
2019/02/23 Python
Python实现微信机器人的方法
2019/09/06 Python
python通用数据库操作工具 pydbclib的使用简介
2020/12/21 Python
java关于string最常出现的面试题整理
2021/01/18 Python
Joseph官网:英国小众奢侈品牌
2019/05/17 全球购物
趣味运动会广播稿
2014/09/13 职场文书
学校党的群众路线教育实践活动对照检查材料
2014/09/24 职场文书
给校长的建议书作文400字
2015/09/14 职场文书