Java面试八股之MySQL主从复制机制简述

  1. MySQL主从复制机制简述

MySQL的主从复制机制是一种数据复制方案,用于在多个服务器之间同步数据。此机制允许从一个服务器(主服务器)到一个或多个其他服务器(从服务器)进行数据的复制,从而增强数据冗余、提高读取性能,并且为灾难恢复提供保障。以下是MySQL主从复制机制的简要概述:

复制过程

二进制日志(Binary Logging):

主服务器上的所有更改(如INSERT、UPDATE、DELETE等)都被记录在二进制日志(binlog)中。

这些更改是以事件的形式记录的,事件中包含了SQL语句或行级别的数据更改描述。

从服务器连接:

从服务器连接到主服务器,请求复制二进制日志中的更改。

从服务器通过I/O线程向主服务器请求二进制日志文件和位置。

日志传输:

主服务器通过一个线程(log dump thread)将二进制日志文件的内容发送给从服务器。

中继日志(Relay Logging):

从服务器接收到的二进制日志事件被存储在本地的中继日志(relay log)中。

中继日志用于缓冲从主服务器接收到的事件,直到它们被应用。

事件应用:

从服务器上的SQL线程从本地的中继日志中读取事件,并在从服务器上执行相应的SQL语句。

这个过程确保了从服务器上的数据与主服务器保持一致。

复制类型

基于语句的复制(SBR):

MySQL记录执行的SQL语句,而不是具体的数据变化。

这种模式通常会产生更小的二进制日志,但在某些情况下可能会遇到数据不一致的问题。

基于行的复制(RBR):

MySQL记录每个事务中每行数据的前后状态。

这种模式更精确,但可能会产生更大的二进制日志。

混合模式复制(MBR):

结合了SBR和RBR的优点,通常使用SBR,但在检测到可能引起不一致性的语句时,会自动切换到RBR。

注意事项

版本兼容性:

主服务器和从服务器应运行相同或兼容的MySQL版本,以避免潜在的兼容性问题。

时间同步:

主服务器和从服务器之间的时间必须同步,以防止时间戳相关的错误。

资源消耗:

复制会消耗网络带宽和磁盘空间,因此需要适当规划和监控。

延迟:

从服务器的数据可能滞后于主服务器,特别是在网络延迟较高或从服务器负载较高的情况下。

通过合理配置和监控,MySQL的主从复制机制可以显著提升系统的可靠性和性能。

如果大家需要视频版本的讲解,欢迎关注我的B站:

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

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

相关文章

Qt 音频编程实战项目

一Qt 音频基础知识 QT multimediaQMediaPlayer 类:媒体播放器,主要用于播放歌曲、网络收音 机等功能。QMediaPlaylist 类:专用于播放媒体内容的列表。 二 音频项目实战程序 //版本5.12.8 .proQT core gui QT multimedia greate…

用户特征和embedding层做Concatenation

要将用户特征与嵌入层进行连接,可以使用深度学习框架(如TensorFlow或PyTorch)中的基本操作。以下是使用PyTorch的示例代码,展示了如何将用户特征与嵌入层连接起来。 示例代码(使用PyTorch) 安装 PyTorch 如…

@Slf4j idea标红Cannot resolve symbol ‘log‘

一、背景 时间久了没有应用idea,打开工程后项目 log 提示报红,未能解析,Cannot resolve symbol log ,Slf4j 注解正常,应用的lombok插件。 检查lombok插件安装情况,发现未安装,重新安装重启idea后正常。 二…

Cesium自定义着色器构件三角面片【闪烁】问题,但是一移动视角就闪烁

问题:已知各个顶点的坐标信息、颜色和索引信息,并自定义绘制三角面片。 但是绘制的三角面片随着视角稍微改动就会出现闪烁现象!!!why? Cesium数据类型的精度问题,例如下面为了获取能接收到高精度坐标信息…

系统架构师考点--信息系统基础知识

大家好。今天我们来总结一下信息系统基础知识的相关考点,每年都会考,一般是在上午场选择题中,占3分左右,其次下午场论文也有可能会出相关的考题。 一、信息系统概述 信息系统: 是由计算机硬件、网络和通信设备、计算…

selenium,在元素块下查找条件元素

def get_norms_ele_text(self):elementsself.get_norms_elements()locBy.CSS_SELECTOR,"div.sku-select-row-label"by loc[0] # 获取By类型,例如By.CSS_SELECTORvalue loc[1] # 获取具体的CSS选择器字符串,例如"div.sku-select-row-l…

Java虚拟机面试题汇总

目录 1. JVM的主要组成部分及其作用? 1.1 运行时数据区划分? 1.2 哪些区域可能会发生OOM? 1.3 堆和栈的区别? 1.4 内存模型中的happen-before是什么? 2. HotSpot虚拟机对象创建流程? 2.1 类加载过程…

CoppeliaSim的简单教程

文章目录 一、 CoppeliaSim1.0 CoppeliaSim 简介1.1 CoppeliaSim 安装1.2 CoppeliaSim 使用 一、 CoppeliaSim 1.0 CoppeliaSim 简介 CoppeliaSim(原V-REP)是一个机器人仿真平台,里面有很多来自别的公司的机器人模型以及完备的物理引擎,我们可以通过 p…

数据库之SQL(二)

目录 一、简述SQL中如何将“行”转换为“列” 二、简述SQL注入 三、如何将一张表的部分数据更新到另一张表 四、WHERE和HAVING的区别 一、简述SQL中如何将“行”转换为“列” 我们以MySQL数据库为例,来说明行转列的实现方式。 首先,假设我们有一张分…

C# —— FileStream文件流

一个文件进行读写的时候,会变成一个文件流 FileStream类 输入流 用于从文件进行读取文件 输出流,向文件写入操作 I/O 类就是对应文件的操作的类 I/O类 包含各种不同的类 用于执行各种文件操作,创建文件删…

数据库中的schema和database

一、什么是schema schema可以简单理解为就是一个具体的数据库实例,不同的实例可以有不同的组成以及约束规则,比如数据库的字符编码方式、执行引擎等等。一个数据库服务器中可以包含多个schema,就像可以包含多个数据库实例一样。 二、如何创建…

使用stream流过滤对象中相同的属性值

使用stream流过滤对象中相同的属性值 文章目录 使用stream流过滤对象中相同的属性值前言一、使用stream流过滤集合对象中相同属性1.创建一个实体类2.创建一个过滤工具类3.创建一个测试类 总结 前言 我们在开发项目中,有很多需求是需要集合根据某个属性筛选出重复的…

什么是前端?

1、什么是前端? 将产品的UI设计稿在用户终端上实现,这就是前端。 简单来讲,前端要做的就是将产品的UI设计稿在用户终端上实现,因此可以说用户看到的所有视觉和交互都是前端的工作领域。 根据这个定义,我们可以把前端…

移动校园(8): Uniapp 中路由守卫进行用户权限管理--不同用户不同功能

思路,在登录之后将用户类型type写入本地存储,然后在前置路由守卫里面读取然后鉴权。 路由守卫VS拦截器 路由守卫主要管理前端之间页面的跳转 拦截器管理后端交互, 所以说权限管理需要路由守卫来做。 但是没有原生路由守卫,查…

A65 STM32_HAL库函数 之 USART通用驱动 -- A -- 所有函数的介绍及使用

A65 STM32_HAL库函数 之 USART通用驱动 -- A -- 所有函数的介绍及使用 1 该驱动函数预览1.1 HAL_USART_Init1.2 HAL_USART_DeInit1.3 HAL_USART_MspInit1.4 HAL_USART_MspDeInit1.5 HAL_USART_Transmit1.6 HAL_USART_Receive1.7 HAL_USART_TransmitReceive1.8 HAL_USART_Transm…

Echarts桑基图

关于Echarts的使用方法参考:vue2中echarts的使用_vue2中使用echarts-CSDN博客 实现效果: 代码: var sysT {"用采": #2D9BFF,"营销系统": #39BFFF,"ERP": #76C2FF,"财务管控": #5F57FC,"PMS&…

Java面试八股之描述一下MySQL使用索引查询数据的过程

描述一下MySQL使用索引查询数据的过程 1.解析查询语句与查询优化 用户提交一个 SQL 查询语句,MySQL 的查询解析器对其进行词法分析和语法分析,生成解析树。 查询优化器根据解析树、表结构信息、统计信息以及索引信息,决定是否使用 B树索引…

QProgressDialog 在进度条达到最大值时自动关闭,屏蔽esc和cancel按钮

使用QProgressDialog来展示当前任务执行进度 QProgressDialog 默认会在进度达到设定的最大值时自动关闭。 setAutoReset()设置为false或setAutoClose()设置为false时对话框无法自动关闭。 功能设计 任务未完成时,不允许其他操作,对话框设置为模态阻塞…

昇思MindSpore学习总结十二 —— ShuffleNet图像分类

当前案例不支持在GPU设备上静态图模式运行,其他模式运行皆支持。 1、ShuffleNet网络介绍 ShuffleNetV1是旷视科技提出的一种计算高效的CNN模型,和MobileNet, SqueezeNet等一样主要应用在移动端,所以模型的设计目标就是利用有限的计算资源来达…

拖拽排序 + 置顶和置底逻辑的实现

最近在实现拖拽排序、置顶和置底逻辑时遇到了比较恶心的问题。以下为记录 背景 我们系统的排序是基于数据库中的 sort_num 字段进行的,sort_num 值越大,数据排位越靠前。新增数据时,其 sort_num 默认为其 id 值。假设当前有 10 条数据&…