配置mysql 主主模式 GTID

news2024/11/24 15:52:47

文章目录

    • 一、前提
    • 二、修改my.cnf
      • 主1 10.255.131.9
      • 主2 10.255.131.10
    • 三、配置主主
      • 3.1 配置主 10.255.131.9
      • 3.2 配置从 10.255.131.10
      • 3.3 配置主 10.255.131.10
      • 3.4 配置从 10.255.131.9
    • 四、验证
    • 五、同步问题排查以及恢复
      • 5.1 查看同步状态
      • 5.2 查看同步是否数据一致性,延迟多少
      • 5.3 过滤掉常见错误
      • 5.4 同步失败如何恢复

一、前提

两台机器均部署好了mysql;

部署可参考之前的博客: Mysql 8.4.3LTS 的离线部署

二、修改my.cnf

主1 10.255.131.9

vim /etc/my.cnf

[mysqld] 中加入以下内容

# 配置server-id 每个MySQL实例的server-id都不能相同
server-id=9
# MySQL的日志文件的名字
log-bin=mysql_master
# 作为从库时 更新操作是否写入日志 on:写入  其他数据库以此数据库做主库时才能进行同步
log-slave-updates=on
# 同步DML
binlog_format = ROW
# 开启GTID
gtid-mode = ON 
enforce-gtid-consistency = ON 
log-slave-updates = ON
# 多线程复制
slave_parallel_workers = 4

# MySQL系统库的数据不需要同步 我们这里写了3个  更加保险
# 同步数据时忽略一下数据库 但是必须在使用use db的情况下才会忽略;如果没有使用use db 比如create user  数据还是会同步的
replicate-ignore-db=information_schema
replicate-ignore-db=mysql
replicate-ignore-db=performance_schema
replicate-ignore-db=sys
# 使用通配符忽略MySQL系统库的表  这样在create user时也不会进行同步了
replicate_wild_ignore_table=information_schema.%
replicate_wild_ignore_table=mysql.%
replicate_wild_ignore_table=performance_schema.%
replicate_wild_ignore_table=sys.%
# MySQL系统库的日志不计入binlog 这样更加保险了
binlog-ignore-db=information_schema
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=sys

主2 10.255.131.10

修改my.cnf, 只需要修改其中的两个地方,其他内容一样

# 配置server-id 每个MySQL实例的server-id都不能相同
server-id=10
# MySQL的日志文件的名字
log-bin=mysql_slave

my.cnf文件修改完成后,重启mysql

systemctl restart mysql

三、配置主主

主主模式就是配置两个主从。

10.255.131.9(主)->10.255.131.10(从)

10.255.131.10(主)->10.255.131.9(从)

3.1 配置主 10.255.131.9

先登录10.255.131.9(主1)的数据库,依次执行如下命令:


#创建备份的账号 使用MYSQL_NATIVE_PASSWORD的方式加密
create user 'repl_master'@'%' identified with mysql_native_password by 'master_****';
# 对repl_master授予备份的权限
grant replication slave on *.* to 'repl_master'@'%';
# 刷新权限
flush privileges;

3.2 配置从 10.255.131.10

登录到10.255.131.10(主2) 中,执行如下命令:

mysql> CHANGE MASTER TO 
MASTER_HOST='10.255.131.10',
MASTER_USER='repl_master',
MASTER_PASSWORD='master_****',
MASTER_PORT=3306,
MASTER_AUTO_POSITION = 1;

在这里插入图片描述

mysql> START SLAVE;
mysql> SHOW SLAVE STATUS\G;

image-20241029192846975

这样,

10.255.131.9(主1)->10.255.131.10(主2)的主从就搭建好了。

然后,我们再反过来,搭建

10.255.131.10(主2)->10.255.131.9(主1)的主从

3.3 配置主 10.255.131.10

登录10.255.131.10(主2)的数据库,依次执行如下命令:

#创建备份的账号 使用MYSQL_NATIVE_PASSWORD的方式加密
create user 'repl_slave'@'%' identified with mysql_native_password by 'slave_****';
# 对repl_slave授予备份的权限
grant replication slave on *.* to 'repl_slave'@'%';
# 刷新权限
flush privileges;
# 查看MySQL主节点的状态
show master status;

image-20241029193053920

binlog文件的名字,mysql_master.000001,和位置,也就是830。

3.4 配置从 10.255.131.9

登录到10.255.131.9(主1),执行如下命令:

mysql> CHANGE MASTER TO 

MASTER_HOST='10.255.131.9',

MASTER_USER='repl_slave',

MASTER_PASSWORD='slave_****',

MASTER_PORT=3306,

MASTER_AUTO_POSITION = 1;

在这里插入图片描述

mysql> START SLAVE;
mysql> SHOW SLAVE STATUS\G;

image-20241029193203509

四、验证

由于上述的my.cnf中将创建用户,创建表的行为给屏蔽同步了。

注释相关代码后 重启,发现在10.255.131.9上执行的创建用户与表的动作;

10.255.131.10上已经同步过去了。

此外创建分区并不会导致同步的报错以及异常;

CALL P_ADD_TAB_PARTITION_THAT_VERY_DAY(‘MON_DATA_CUR’);

两台服务器均正常创建了今天的分区;

五、同步问题排查以及恢复

5.1 查看同步状态

同步状态是否正常可通过sql查询;

mysql> show slave status\G;

以下两个属性均为yes;说明同步状态正常

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

如果有任何为No,可以查询Last_SQL_Error上次同步失败的sql;如何恢复,请看5.4

5.2 查看同步是否数据一致性,延迟多少

mysql> show slave status\G;

Seconds_Behind_Master: 为0说明数据同步完成,这个属性表示的是从库同步主库的延迟时间,单位秒;

5.3 过滤掉常见错误

常见的有1032错误码;

image-20241029193448260

binlog中变更的那行在表中不存在,导致主从失败; 该错误很常见,可屏蔽

my.cnf可配置slave-skip-errors=1032

重启mysql,就可以跳过日志中的1032错误码

也可以配置

# 跳过所有错误 slave-skip-errors=all

5.4 同步失败如何恢复

如果主库有个错误的sql执行导致报错,或者主从库数据结构不一致等原因导致同步报错;

这种情况如何恢复同步呢;

基本上就这三步;

mysql> stop slave;

mysql> reset slave;

mysql> start slave;

如果起不来可能是binlog记录的位置不一致。这时候reset slave下再重启;

复杂的错误导致数据不一致的情况

  1. 全量同步

可以采取删除从库数据库,主库锁库只读。然后全量备份再恢复到从库中,再建立主从同步的链接,以此来恢复。

锁表:FLUSH TABLES WITH READ LOCK;

解锁:UNLOCK TABLES;

  1. 跳过部分错误(没啥用)

mysql>stop slave ;

~~mysql>SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;~~跳过一个事务

mysql>start slave;

  1. 对于复杂的报错无法解决的时候如果同步并恢复主从呢

在此举例主从,主主的模式一样,就是操作两遍。

首先从数据库停止同步;并删除主从连接配置信息

mysql> stop slave;

mysql> reset slave all;

主数据库中删除binlog,重新记录binlog

mysql> reset master;

借助工具,手动的同步两个数据库,主数据库数据同步到从数据库中;Navicat,SQLyog 均可,好用。

从数据库上建立连接GTID

mysql> CHANGE MASTER TO 

MASTER_HOST='10.255.131.9',

MASTER_USER='repl_master',

MASTER_PASSWORD='master_****',

MASTER_PORT=3306,

MASTER_AUTO_POSITION = 1;

启动从库同步;

mysql> start slave;

这样就可以恢复主从的同步了。

这是没法通过 reset slave; 恢复同步时候的实用的解决方式,要注意mysql同步之前最好做下必要的备份,防止数据丢失。

总之数据库的同步是一个复杂的情况,如果生产上发现同步异常,数据库数据不一致等情况,可以找专业DBA。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2228944.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Vulnhub靶场】DC-5

DC-5靶机下载地址: https://download.vulnhub.com/dc/DC-5.zip 目标 本机IP:192.168.118.128 靶机IP:192.168.118.0/24 信息收集 扫描存活主机,扫描端口,扫描服务 第一步使用nmap扫描出目标IP为:192.168…

docker 安装kuboard

mkdir /root/kuboard-data docker run --restartunless-stopped -p 8453:80 -d --name kuboard -e KUBOARD_AGENT_SERVER_TCP_PORT8453 -e KUBOARD_ENDPOINThttps://192.168.31.177 -v /root/kuboard-data:/data eipwork/kuboard:v3http://192.168.31.177:8453/ 默认账号&…

SpringBoot和弦:创建Web音乐网站指南

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及,互联网成为人们查找信息的重要场所,二十一世纪是信息的时代,所以信息的管理显得特别重要。因此,使用计算机来管理音乐网站的相关信息成为必然。开发合适的音…

LinkedList和链表(下)

1. 什么是LinkedList 在练习了单链表的自我实现和单链表的一些习题之后,我们正式来认识一下java提供的LinkedList,这是一种双向链表结构,在增删元素的时候效率比较高,不需要像ArrayList一样搬运元素.但是在查找方面效率比较低(需要遍历链表),ArrayList效率就比较高(直接由数组下…

DevOps赋能:优化业务价值流的实战策略与路径(下)

下篇:加速工作项流动与持续改进优化 —— 跨越差距,迈向卓越交付 在上篇中,我们已经深入探讨了看板方法的四大核心实践,它们共同致力于实现“顺畅且高质量地交付价值”的终极目标。然而,理想与现实之间往往存在一定的…

day14:RSYNC同步

一,概述 概述 rsync (开源)是一个高效的文件同步和传输工具,广泛用于 Linux 和 Unix 系统中。它可以在本地和远程系统之间同步文件和目录,同时支持增量备份,能够只传输更改过的文件部分,以减少…

Leaflet查询矢量瓦片偏移的问题

1、问题现象 使用Leaflet绘制工具查询出来的结果有偏移 2、问题排查 1)Leaflet中latLngToContainerPoint和latLngToLayerPoint的区别 2)使用Leaflet查询需要使用像素坐标 3)经排查发现,container获取的坐标是地图容器坐标&…

JSP水果商城管理系统WEB项目

一、项目简介 > FruitsDay 是一个用于销售水果的WEB商城项目。 > 该项目主要通过Java和JSP实现,旨在帮助用户实现网购水果,并帮助商家管理水果库存。 > 项目采用Maven构建,使用JSP和Servlet实现,比较适合JAVA初学者…

Rust 力扣 - 1. 两数相加

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 我们使用一个全局的备忘录,然后我们遍历数组,如果当前元素在备忘录里面找到了,就返回备忘录里面记录的下标和当前下标记录,没找到就把当前元素匹配的元素和当前元素…

ssm016基于 Java Web 的校园驿站管理系统(论文+源码)_kaic

毕 业 设 计(论 文) 题目:校园驿站管理系统的设计与实现 摘 要 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好…

NCCL安装(Ubuntu等)

目录 一、NCCL的定义二、安装NCCL的原因1、加速多GPU通信2、支持流行的深度学习框架3、提高计算效率4、易于使用和集成5、可扩展性 三、NCCL安装方法1、下载安装包2、更新APT数据库3、使用APT安装libnccl2包,另外,如果需要使用NCCL编译应用程序&#xff…

Spring的IOC技术(配置文件形式)

目录 一、什么是IOC 二、IOC的程序入门 1.创建mavenJava项目,引入依赖 2.编写接口和实现类 3.编写spring核心配置文件(applicationContext.xml) 4.测试类 5.测试结果-------一个对象 三、Spring框架的Bean管理的配置文件 四、实例化Bean对象的三种方式 1.无…

论文阅读(三十二):EGNet: Edge Guidance Network for Salient Object Detection

文章目录 1.Introduction2.Related Works3.Salient Edge Guidance Network3.1Complementary information modeling3.1.1Progressive salient object features extraction3.1.2Non-local salient edge features extraction 3.2One-to-one guidance module 4.Experiments4.1Imple…

深度学习:卷积神经网络中的img2col

im2col 是一种在卷积神经网络(CNN)中常用的技术,用于将输入图像数据转换为适合卷积操作的矩阵形式。通过这种转换,卷积操作可以被高效地实现为矩阵乘法,从而加速计算。 在传统的卷积操作中,卷积核&#xff…

java:入门基础(1)

练习一:文字版格斗游戏 需求: ​ 格斗游戏,每个游戏角色的姓名,血量,都不相同,在选定人物的时候(new对象的时候),这些信息就应该被确定下来。 举例: ​ 程序运行之后…

计算机毕业设计 | springboot+vue电影院会员管理系统 影院后台管理(附源码)

1,项目背景 随着互联网时代的到来,同时计算机网络技术高速发展,网络管理运用也变得越来越广泛。因此,建立一个B/S结构的电影院会员管理系统;电影院会员管理系统的管理工作系统化、规范化,也会提高影院形象…

TypeScript(中)+算法(二)

文章目录 算法排序冒泡排序选择排序 TS类型声明类型推断类型总览js中的数据类型ts中的数据类型原始类型和包装对象原始类型包装对象自动装箱 常用类型与语法anyunknownnevervoidvoid 与 undefined总结 算法 排序 有十种排序算法,分别是:冒泡排序&#…

算法定制LiteAIServer视频智能分析软件的过亮、过暗及抖动检测应用场景

在现代社会中,视频监控系统扮演着举足轻重的角色,其视频质量直接关乎监控系统的可靠性与有效性。算法定制LiteAIServer通过引入抖动检测和过亮过暗检测功能,为视频监控系统的稳定性和用户体验带来了显著提升。 以下是对这两种功能的技术实现、…

【隐私计算篇】全同态加密应用场景案例(隐私云计算中的大模型推理、生物识别等)

1.题外话 最近因为奖项答辩,一直在忙材料准备,过程非常耗费时间和精力,很难有时间来分享。不过这段时间虽然很忙碌,但这期间有很多新的收获,特别是通过与领域内专家的深入交流和评审过程,对密码学和隐私计算…

elasticsearch 8.x 插件安装(三)之拼音插件

elasticsearch 8.x 插件安装(三)之拼音插件 elasticsearch插件安装合集 elasticsearch插件安装(一)之ik分词器安装(含MySQL更新) elasticsearch 8.x插件(二)之同义词安装如何解决…