MySQL - 读写分离、一主一从、双主双从

news2024/12/30 2:05:58

文章目录

  • 读写分离
  • 一、介绍
  • 二、一主一从
    • 2.1 原理
    • 2.2 服务器准备
    • 2.3 一主一从读写分离
      • 2.3.1 MyCat 配置
        • 2.3.1.1 schema.xml
        • 2.3.1.2 server.xml配置
  • 三、双主双从
    • 3.1 双主双从介绍
    • 3.2 服务器准备
    • 3.3 双主双从读写分离
      • 3.3.1 主库配置
        • 3.3.1.1 211主库配置
        • 3.3.1.2 213主库配置
      • 3.3.2 从库配置
        • 3.3.2.1 212 从库配置
        • 3.3.2.2 214从库配置
    • 3.4 从库关联主库
      • 3.4.1 两台从库配置关联主库
      • 3.4.2 主库相互复制
    • 3.5 双主双从读写分离
      • 3.5.1 schema.xml
      • 3.5.2 server.xml
      • 3.5.2 server.xml

读写分离

一、介绍

读写分离,简单地说是把对数据库的读和写操作分开,以对应不同的数据库服务器。主数据库提供写操作,从数据库提供读操作,这样能有效地减轻单台数据库的压力。

MyCat实现读写分离的话,主要通过两个组件来实现:

​ readHost、writeHost

读写分离它的前提是基于主从复制

主从复制的原理是基于MySQL的二进制日志Binlog来实现的

如果是读的操作,我们就直接连接从节点,如果是写的操作,直接连主节点

应用程序不用直接连接MySQL,否则会很繁琐,因为会有多个服务器数据库

我们直接连接MyCat即可,让MyCat决定应用程序在执行增删改操作时路由到哪个数据库节点(比如,增删改操作路由到主库,查询操作路由到从库)

image-20230602142423735

详细主从复制知识点介绍在这边文章中MySQL — 主从复制介绍

二、一主一从

2.1 原理

MySQL的主从复制,基于二进制日志(binlog)实现的

详细主从复制知识点介绍在这边文章中MySQL — 主从复制介绍

image-20230602145641194

2.2 服务器准备

主从复制的搭建可以参照MySQL — 主从复制介绍文章

image-20230602145840473

2.3 一主一从读写分离

2.3.1 MyCat 配置

2.3.1.1 schema.xml

MyCat控制后台数据库的读写分离和负载均衡由schema.xml文件datahost标签的balance属性控制(默认的balance是0,我们要进行修改)

注意看我们dataHost标签中writeHost和readHost标签的URL属性,是不一样的,分别是211、212,主库负责写操作,从库负责读操作

比如说下面的配置是主库的地址

<writeHost host="master1" url="jdbc:mysql://192.168.200.211:3306?useSSL=false&amp;serverTimezone=Asia/Shanghai&amp;characterEncoding=utf8"user="root"   password="1234" >

下面的配置是从库的配置

<readHost host="slave1" url="jdbc:mysql://192.168.200.212:3306?
useSSL=false&amp;serverTimezone=Asia/Shanghai&amp;characterEncoding=utf8"
user="root" password="1234" />

在读写分离的时候可以不指定逻辑表,如果不指定逻辑表它会自动的去加载所在的数据节点所对应的数据库,然后去读取这个数据库当中所有的表结构作为逻辑表

image-20230602150821803

writeHost代表的是写操作对应的数据库,readHost代表的是读操作对应的数据库。 所以我们要想实现读写分离,就得配置writeHost关联的是主库,readHost关联的是从库。

​ 仅仅配置好了writeHost以及readHost还不能完成读写分离,还需要配置一个非常重要的负责均衡的参数 balance

参数值含义
0不开启读写分离机制 , 所有读操作都发送到当前可用的writeHost上
1全部的readHost 与 备用的writeHost 都参与select 语句的负载均衡(主要针对于双主双从模式)
2所有的读写操作都随机在writeHost , readHost上分发
3所有的读请求随机分发到writeHost对应的readHost上执行, writeHost不负担读压力

所以,在一主一从模式的读写分离中,balance配置1或3都是可以完成读写分离的

2.3.1.2 server.xml配置

我们要给用户配置一下可以访问我们新创建的数据库的权限

<user name="root" defaultAccount="true">
   <property name="password">123456</property>
   <property  name="schemas">SHOPPING,ITCAST,ITCAST_RW</property>
   
   <!-- 表级 DML 权限设置 -->
   <!--
     <privileges check="true">
       <schema name="DB01" dml="0110" >
       <table name="TB_ORDER" dml="1110"></table>
       </schema>
     </privileges>
    -->
    
</user>

三、双主双从

对于一主一从,主节点Master宕机之后,业务系统就只能够读,而不能写入数据了

为了解决这一个问题,我们可以采用双主双重的架构

双主双从意味着要有四台服务器

3.1 双主双从介绍

Master1数据会同步到Master2和Slave1

Master2数据会同步到Master1和Slave2

此时Master1与Master2互为备机

image-20230602155020087

这种情况下我们一般令一个主机Master1用于处理所有请求,它的从机Slave1和另一台主机Master2还有它的从机Slave2负责所有读请求。

当Master1主机宕机后,Master2主机负责写请求

3.2 服务器准备

image-20230602161006818

3.3 双主双从读写分离

3.3.1 主库配置

3.3.1.1 211主库配置

  • my.int/my.cnf 配置文件修改

所涉及到的四个服务器都需要修改

#mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 2^32-1,默认为1
server-id=1
#指定同步的数据库
binlog-do-db=db01
binlog-do-db=db02
binlog-do-db=db03
# 在作为从数据库的时候,有写入操作也要更新二进制日志文件
log-slave-updates

binlog-do-db参数在之前主从复制的时候讲到过,代表我们要把数据同步到哪几个数据库

指定的数据库会进行主从复制,别的数据库是不会进行主从复制的

log-slave-updates ,在作为从数据库的时候 为什么也要更新二进制日志文件?

因为这个从库也是其他库的主库,它的从库需要从主库当中读取二进制日志文件

server-id 四台服务器不同,如下所示

image-20230602161613686

  • 重启SQL服务器
systemctl restart mysqld
  • 创建账户并授权
#创建itcast用户,并设置密码,该用户可在任意主机连接该MySQL服务
CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123456';

#为 'itcast'@'%' 用户分配主从复制权限
GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
  • 查看二进制日志坐标
show master status ;

3.3.1.2 213主库配置

image-20230602162714303

  • 修改配置文件my.ini/my.cnf

    只有server-id与211配置不同

#mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 2^32-1,默认为1
server-id=3

#指定同步的数据库
binlog-do-db=db01
binlog-do-db=db02
binlog-do-db=db03
# 在作为从数据库的时候,有写入操作也要更新二进制日志文件
log-slave-updates
  • 重启MySQL服务器
systemctl restart mysqld
  • 创建账户并授权

    要有主从复制的权限

#创建itcast用户,并设置密码,该用户可在任意主机连接该MySQL服务
CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123456';

#为 'itcast'@'%' 用户分配主从复制权限
GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
  • 查看二进制日志坐标
show master status ;

3.3.2 从库配置

3.3.2.1 212 从库配置

image-20230602163811152

  • 修改配置文件 my.cnf/my.ini

    不需要指定同步数据库,因为仅仅是从库,不是什么库的主库

#mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 232-1,默认为1
server-id=2
  • 重新启动MySQL服务器
systemctl restart mysqld

3.3.2.2 214从库配置

image-20230602164020389

  • 修改配置文件 my.cnf/my.ini

    不需要指定同步数据库,因为仅仅是从库,不是什么库的主库

#mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 232-1,默认为1
server-id=4
  • 重新启动MySQL服务器
systemctl restart mysqld

3.4 从库关联主库

3.4.1 两台从库配置关联主库

slave1对应的是master1,slave2对应的是master2

image-20230602164335092

  • Slave1关联Master1
CHANGE MASTER TO MASTER_HOST='192.168.200.211', MASTER_USER='itcast',
MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002',
MASTER_LOG_POS=663;
  • Slave2关联Master2
CHANGE MASTER TO MASTER_HOST='192.168.200.213', MASTER_USER='itcast',
MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002',
MASTER_LOG_POS=663;
  • 启动两台从库主从复制,查看从库状态
start slave;
show slave status \G;

3.4.2 主库相互复制

Master2 复制 Master1,Master1 复制 Master2

image-20230602170941059

  • 在Master1上执行
CHANGE MASTER TO MASTER_HOST='192.168.200.213', MASTER_USER='itcast',
MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002',
MASTER_LOG_POS=663;
  • 在Master2上执行
CHANGE MASTER TO MASTER_HOST='192.168.200.211', MASTER_USER='itcast',
MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002',
MASTER_LOG_POS=663;
  • 启动两台从库主从复制,查看从库状态
start slave;
show slave status \G;

3.5 双主双从读写分离

3.5.1 schema.xml

​ MyCat控制后台数据库的读写分离和负载均衡由schema.xml文件datahost标签的balance属性控制,通过writeType及switchType来完成失败自动切换的。

image-20230602172241770

  • writeType

    0 : 写操作都转发到第1台writeHost, writeHost1挂了, 会切换到writeHost2上;

    1 : 所有的写操作都随机地发送到配置的writeHost上 ;

  • switchType

    -1 : 不自动切换

    1 : 自动切换

  • balance=“1”

    我们在上面介绍过了,可以看一下之前的内容

    代表全部的 readHost 与 stand by writeHost 参与 select 语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且 M1 与 M2 互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡 ;

3.5.2 server.xml

<user name="root" defaultAccount="true">
   <property name="password">123456</property>
   <property name="schemas">SHOPPING,ITCAST,ITCAST_RW2</property>
   <!-- 表级 DML 权限设置 -->
   <!--
     <privileges check="true">
       <schema name="DB01" dml="0110" >
         <table name="TB_ORDER" dml="1110"></table>
       </schema>
     </privileges>
   -->
</user>

M1 与 M2 互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡 ;

3.5.2 server.xml

<user name="root" defaultAccount="true">
   <property name="password">123456</property>
   <property name="schemas">SHOPPING,ITCAST,ITCAST_RW2</property>
   <!-- 表级 DML 权限设置 -->
   <!--
     <privileges check="true">
       <schema name="DB01" dml="0110" >
         <table name="TB_ORDER" dml="1110"></table>
       </schema>
     </privileges>
   -->
</user>

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

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

相关文章

rknn ffmpeg硬解码环境配置以及调用代码

查看rk3588系统信息 cat /proc/version 本编译在 Debain/ubuntu20.04 这两家板子上编译成功。 安装依赖 sudo apt-get install libx264-dev sudo apt-get install libfaac-dev sudo apt-get install libmp3lame-dev sudo apt-get install libtheora-dev sud…

综合能效管理:全面助力企业节能降耗 86型双联明装墙插面板智选套装上市

能源的综合利用效率主要体现在安全性、节能性及经济性方面。随着物联网智能技术的发展&#xff0c;能源监测与安全监控管理不仅面向能源生产、存储、传输、配送、运用环节&#xff0c;还需要更广泛地、深入地涵盖到分布式能源节点的能源使用消耗的全过程&#xff0c;基于对用户…

官宣代言人王一博,老板电器为打开厨电增量市场提供新思路

文丨智能相对论 作者丨佘凯文 最近两年&#xff0c;全球都处于一个经济结构调整的时期&#xff0c;许多行业深受影响。像国内厨电行业&#xff0c;在诸多因素影响下&#xff0c;就迈向了稳定发展的新常态。 与此同时&#xff0c;行业内部竞争也开始发生改变&#xff0c;从过…

自学黑客(网络安全),一般人我劝你还是算了吧(自学网络安全学习路线--第一章 网络协议基础 )

一、自学网络安全学习的误区和陷阱 1.不要试图先成为一名程序员&#xff08;以编程为基础的学习&#xff09;再开始学习 我在之前的回答中&#xff0c;我都一再强调不要以编程为基础再开始学习网络安全&#xff0c;一般来说&#xff0c;学习编程不但学习周期长&#xff0c;而且…

5月面试碰壁15次,我哭了....

3年测试经验原来什么都不是&#xff0c;只是给你的简历上画了一笔&#xff0c;一直觉得经验多&#xff0c;无论在哪都能找到满意的工作&#xff0c;但是现实却是给我打了一个大巴掌&#xff01;事后也不会给糖的那种... 先说一下自己的个人情况&#xff0c;普通二本计算机专业…

FastChat(小羊驼模型)部署体验

简介 前段时间&#xff0c;斯坦福发布了Alpaca&#xff0c;是由Meta的LLaMA 7B微调而来&#xff0c;仅用了52k数据&#xff0c;性能可以与GPT-3.5匹敌。 FastChat集成了Vicuna、Koala、alpaca、llama等开源模型&#xff0c;其中Vicuna号称能够达到gpt-4的90%的质量&#xff0…

Java基础(项目1)——项目设计分层 dao + service + test +ui + exception + log + util

目录 引出DAO层---和数据库交互1.通过IO流存储到dat文件2.通过JDBC存储到数据库【测试】用junit进行测试&#xff1a;Test注解 Service层---处理业务1.项目设计分层初步2.service处理业务相关3.和UI层以及dao层进行交互 UI层界面---控制台&#xff0c;单例模式1.创建单例的方法…

牛客-【237题】算法基础精选题单

2023年06月02日更新 NOIP2007 字符串的展开NOIP2009 多项式输出NOIP2010 机器翻译 NOIP2007 字符串的展开 第一道题目花费的时间是最多的&#xff0c;还wa了几次 需要特别注意的一个特殊情况时 1-a 这个时候a的ASCII是大于1的&#xff0c;需要满足的一个条件是’-前后的符号属…

Bugku 本地管理员

打开链接 F12查看源码&#xff0c;发现了一个base64字符串 解码得到test123&#xff0c;猜测是密码 输入用户admin&#xff0c;密码test123 尝试登录&#xff0c;发现不行 要求似乎只允许本地访问&#xff0c;于是使用bp抓包改包后重发 在请求头加上 x-forwarded-for: 127.0…

Unity中影响性能的因素

原文链接&#xff1a;https://blog.csdn.net/Mq110m/article/details/130435557 Unity中的渲染优化 移动平台的特点 PC平台相比&#xff0c;移动平台上的GPU架构有很大的不同。由于处理资源等条件的限制&#xff0c;移动设备上的GPU架构专注于尽可能使用更小的带宽和功能&am…

【高数+复变函数】Laplace变换的性质

文章目录 【高数复变函数】Laplace变换的性质一、性质1. 线性性质2. 微分性质3. 像函数的微分性质4. 积分性质5. 象函数的积分性质6. 位移性质7. 延迟性质 【高数复变函数】Laplace变换的性质 通过上一节【高数复变函数】Laplace变换的学习&#xff0c;我们知道了Laplace的基本…

MySQL】- 04 MVCC实现原理

MVCC的实现原理 隐式字段undo日志Read View(读视图)整体流程例子 MVCC的目的就是多版本并发控制&#xff0c;在数据库中的实现&#xff0c;就是为了解决读写冲突&#xff0c;它的实现原理主要是依赖记录中的 3个隐式字段&#xff0c;undo日志 &#xff0c;Read View 来实现的。…

同时处理多个聊天,无需头疼

引入实时聊天的想法令人生畏。您正在打开新渠道的闸门&#xff0c;这是添加到您已经不断增长的要管理的应用程序列表中的另一件事。如果实时聊天给您和您的团队增加了如此大的压力&#xff0c;那么也势必不会有很大的成效。 实时聊天正日益成为一种必不可少的支持工具&#xf…

Compose 中 TextField 的有效状态管理

Compose 中 TextField 的有效状态管理 为了防止同步问题和意外行为: 避免在输入和更新TextField状态之间出现延迟/异步行为。避免使用响应式流收集StateFlow的数据来保存TextField状态&#xff0c;例如使用默认调度程序。使用Compose API&#xff0c;例如MutableState<Stri…

C++练习

整理思维导图有以下定义&#xff0c;说明哪些量可以改变哪些不可以改变&#xff1f; const char *p; const (char *) p; char *const p; const char* const p; char const *p; (char *) const p; char const* const p; 3.总结命名空间使用时的方式和注意事项 1. 2. const cha…

Spring IOC - FactoryBean源码解析

​​​​​1. 介绍 FactoryBean是Spring框架中的一个接口&#xff0c;它允许我们自定义一个工厂类&#xff0c;用于创建和管理Spring容器中的Bean实例。FactoryBean接口定义了两个方法&#xff1a; getObject()&#xff1a;用于返回一个Bean实例&#xff0c;这个方法可以自定义…

创建型设计模式04-建造者模式

✨作者&#xff1a;猫十二懿 ❤️‍&#x1f525;账号&#xff1a;CSDN 、掘金 、个人博客 、Github &#x1f389;公众号&#xff1a;猫十二懿 建造者模式 1、建造者模式介绍 建造者模式是一种创建型设计模式&#xff0c;用于将一个复杂对象的构造过程与其表示分离开来&…

七面蚂蚁金服,超硬核面经,已拿Offer!!

刚面试了蚂蚁金服&#xff0c;给大家分享下这些硬核的面试经验 一面&#xff1a;50分钟 1.自我介绍 2.之前的实习经历提问 3.实习做过什么项目&#xff0c;负责什么 4.进程线程 5.java的垃圾回收 6.数据库简单sql语句 7.事务隔离 8.测试微信点赞 9.对测试的了解 10.编程&…

【LeetCode每日一题】——2269.找到一个数字的 K 美丽值

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【解题思路】八【时间频度】九【代码实现】十【提交结果】 一【题目类别】 滑动窗口 二【题目难度】 简单 三【题目编号】 2269.找到一个数字的 K 美丽值 四【题目描述…

第二十二篇、基于Arduino uno,控制五线四相步进电机实现正转和反转——结果导向

0、结果 说明&#xff1a;步进电机可以旋转指定角度&#xff0c;例如转了九十度就停止&#xff0c;如果想一直转也是可以的&#xff0c;程序里面已写&#xff0c;而且也有正反转。如果是你想要的&#xff0c;可以接着往下看。 1、外观 说明&#xff1a;五线四相步进电机如下…