mysql高可用双主配置

2024-04-05 21:58

本文主要是介绍mysql高可用双主配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.环境配置
master A  192.168.0.109
master B  192.168.0.112
都已安装完毕mysql 版本为5.7.12
2.复制配置
A
B
server-id=1
server-id=2
log-bin=mysql-master-bin
log-bin=mysql-master-bin
binlog_format= row
binlog_format= row
relay_log_recovery=1
relay_log_recovery=1
log_slave_updates=1
log_slave_updates=1
slave-skip-errors=all
slave-skip-errors=all
auto-increment-offset=1
auto-increment-offset=2
auto-increment-increment=2
auto-increment-increment=2
gtid-mode=on
gtid-mode=on
enforce-gtid-consistency=true
enforce-gtid-consistency=true
参数说明:
binlog_format: 二进制日志的格式,有row、statement和mixed几种类型。
relay_log_recovery: 当slave从库宕机后,假如relay-log损坏了,导致一部分中继日志没有处理,则自动放弃所有未执行的relay-log, 并且重新从master上获取日志,这样就保证了relay-log的完整性。
log_slave_updates: 表示slave将复制事件写进自己的二进制日志。当设置log_slave_updates时,你可以让slave扮演其它slave的master。此时,slave把SQL线程执行的事件写进行自己的二进制日志(binary  log),然后,它的slave可以获取这些事件并执行它,slave可以是其它slave的master,从而扩散master的更新。
slave-skip-errors:跳过主从复制出现的错误 
auto-increment-offset: 自增长字段从那个数开始,他的取值范围是1 .. 65535
auto-increment-increment: 自增长字段每次递增的量,其默认值是1,取值范围是1 .. 65535
在主主同步配置时,需要将两台服务器的auto_increment_increment增长量都配置为2,而要把auto_increment_offset分别配置为1和2。 这样才可以避免两台服务器同时做更新时自增长字段的值之间发生冲突。参考: http://dev.mysql.com/doc/refman/5.0/en/replication-options-master.html
gtid-mode=on:启用gtid类型,基于事务复制,否则就是普通的复制架构database
enforce-gtid-consistency=true:强制GTID的一致性
slave-parallel-type='logical_clock':基于组提交的并行复制方式,默认database 基于库的并行复制方式
slave-paralles-workers=4:设定从服务器的SQL线程数;0表示关闭多线程复制功能;值与你要复制的数据库数目相同即可;
master-info-repository=TABLE :主服信息记录库=表/文件,多源复制需要配置
relay-log-info-repository=TABLE:中继日志信息记录库,多源复制需要配置
sync-master-info=1:同步主库信息

3.步骤
1)按照2中配置修改my.cnf文件,并重启数据库
可以通过如下命令查看:
show master status \G   查看master信息
show variables like 'gtid%';  查看gtid-mode开启状态
2)在master A上创建复制用户:
>create user 'repltest'@'192.168.0.%'  identified by 'abc123' ;
>grant  replication slave on *.* to 'repltest'@'192.168.0.%';
3)在master B建立change master复制信道
>change master to master_host='192.168.0.109',
>master_user='repltest',
>master_password='abc123',
>MASTER_AUTO_POSITION=1;
启动复制 start slave
通过 show slave status \G 查看slave状态

可以查看在master新增的复制用户也通过了过来。
4)在master A建立change master复制信道
>change master to master_host='192.168.0.112',
>master_user='repltest',
>master_password='abc123',
>MASTER_AUTO_POSITION=1;
启动复制 start slave
4.测试同步复制
1)在master A创建数据库 和表 并插入数据
mysql> create database test_db;
mysql> create table temp(id int primary key not null auto_increment,a int,b int,c int as (a*b));
mysql> insert into temp (a,b)values(1,2),(3,4),(5,6);
可以在master B查看数据正常同步。
2)在master B上insert数据也可以及时同步masterA;

配置了双主复制,A和B都可以读写,后续可以配置 Keepalived实现双主热备,具体参考:
http://lizhenliang.blog.51cto.com/7876557/1362313

这篇关于mysql高可用双主配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878254

相关文章

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满