首页 > 数据库 >Java面试八股之MySQL主从复制机制简述

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

时间:2024-07-08 18:29:07浏览次数:21  
标签:主从复制 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站:

标签:主从复制,Java,二进制,复制,MySQL,服务器,日志
From: https://blog.csdn.net/u012151345/article/details/140272999

相关文章

  • Maven工程下:alibaba fastjson2的各种序列化:java对象转json对象、json对象转java对象
    pom文件导入fastjson2坐标:<dependency><groupId>com.alibaba.fastjson2</groupId><artifactId>fastjson2</artifactId><version>2.0.51</version></dependency>UserVO对象:@Data@AllArgsConstructor......
  • java比较json对象是否相等
    一、需求需要对比这2个json字符串是否完全一样(不用管顺序)1Stringdui="{\"adGroupVO\":{\"campaignId\":\"CAMPAIGN201912101000004559\",\"adGroupChannel\":{\"channelType\":\"SMS\",\"resourceCode\&......
  • mysql函数大全
    描述:巩固一下,避免和oracle函数混淆。字符串函数函数描述ASCII(str)返回字符串str的第一个字符的ASCII码CHAR_LENGTH(str)返回字符串str的字符数CONCAT(str1,str2,...strn)将字符串str1、str2、...strn合并为一个字符串CONCAT_WS(splitStr,str1,str2,.........
  • Java并发基础
    多线程的出现是要解决什么问题的?本质什么?CPU、内存、I/O设备的速度是有极大差异的,为了合理利用CPU的高性能,平衡这三者的速度差异,计算机体系结构、操作系统、编译程序都做出了贡献,主要体现为:CPU增加了缓存,以均衡与内存的速度差异;//导致可见性问题操作系统增加了进程......
  • 如何优化Java中的文件读写性能?
    如何优化Java中的文件读写性能?大家好,我是微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!1.使用缓冲流提升文件读写效率1.1.使用BufferedInputStream和BufferedOutputStream在Java中,使用缓冲流可以显著提升文件读写的效率,尤其是对于大文件而言。以下是一个简单......
  • 使用Java构建可靠的分布式缓存系统
    使用Java构建可靠的分布式缓存系统大家好,我是微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!1.分布式缓存系统概述在现代软件架构中,分布式缓存系统扮演着至关重要的角色,它能够显著提升系统的性能和扩展性。本文将探讨如何使用Java构建一个可靠的分布式缓存系统,利......
  • 深入理解Java中的反射与动态代理
    深入理解Java中的反射与动态代理大家好,我是微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!1.反射介绍在Java编程中,反射(Reflection)是指在运行时动态获取类的信息并操作类或对象的能力。Java的反射机制允许程序在运行时获取类的信息(例如类的方法、字段、注解等),并且......
  • MySQL MVCC实现原理
    MySQL的InnoDB存储引擎使用多版本并发控制(MVCC,Multi-VersionConcurrencyControl)机制来支持高并发的读写操作,同时保证事务的隔离性和一致性。MVCC允许不同的事务看到不同的数据版本,从而减少了锁的竞争,提高了数据库的并发性能。隐式字段InnoDB在每行记录中添加了几个隐藏的......
  • Java 如何在volatile内部调用接口
    在Java中,volatile关键字通常用于确保变量的可见性和有序性,而不是用来修饰接口或方法调用的。volatile修饰的变量会被立即同步到主存,并且在每次访问时都会从主存中重新读取,而不是从缓存中读取。这意味着对volatile变量的修改对所有线程都是可见的。然而,我们的需求似乎是在一个被......
  • java实现excel导出和导入
    1.固定化模板导入导出/***注意:需要指定列宽*@createTime2022/4/2216:59*@param:filename文件名*@param:columnList列名别名宽度*@param:orderList数据源*示例*ArrayList<String[]>columnList=newArrayList<String[]>(){{*add(n......