数据库主从复制_sqlserver主从复制

数据库主从复制_sqlserver主从复制一、什么是主从复制?主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库;主数据库一般是准实时的业务数据库。二、主从复制的作用(好处,或者说为什么要做主从)重点!1、架构的扩展。业务量越来越大,I/O访问频率过高,单机无法满足,此时做多库的存储,物理服务器增加,负荷增加。2、读写分离,使数据库能支撑更大的并发。主从只负责各自的写和读,极大程度的缓解X锁和S锁争用。在报表中尤其重要。由于部分报表sql语句非常的慢,导致锁表,影响前台服务。如果前台使用master,报表使用slave,那

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、什么是主从复制?
主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库;主数据库一般是准实时的业务数据库。

二、主从复制的作用(好处,或者说为什么要做主从)重点!

1、架构的扩展。业务量越来越大,I/O访问频率过高,单机无法满足,此时做多库的存储,物理服务器增加,负荷增加。

2、读写分离,使数据库能支撑更大的并发。主从只负责各自的写和读,极大程度的缓解X锁和S锁争用。在报表中尤其重要。由于部分报表sql语句非常的慢,导致锁表,影响前台服务。如果前台使用master,报表使用slave,那么报表sql将不会造成前台锁,保证了前台速度。

3、做数据的热备,作为后备数据库,主数据库服务器故障后,可切换到从数据库继续工作,避免数据丢失。

三、主从复制的原理(重中之重):

1.数据库有个bin-log二进制文件,记录了所有sql语句。

2.我们的目标就是把主数据库的bin-log文件的sql语句复制过来。

3.让其在从数据的relay-log重做日志文件中再执行一次这些sql语句即可。

4.下面的主从配置就是围绕这个原理配置

5.具体需要三个线程来操作:

**1.binlog输出线程:**每当有从库连接到主库的时候,主库都会创建一个线程然后发送binlog内容到从库。

在从库里,当复制开始的时候,从库就会创建两个线程进行处理:

**2.从库I/O线程:**当START SLAVE语句在从库开始执行之后,从库创建一个I/O线程,该线程连接到主库并请求主库发送binlog里面的更新记录到从库上。从库I/O线程读取主库的binlog输出线程发送的更新并拷贝这些更新到本地文件,其中包括relay log文件。

**3.从库的SQL线程:**从库创建一个SQL线程,这个线程读取从库I/O线程写到relay log的更新事件并执行。

可以知道,对于每一个主从复制的连接,都有三个线程。拥有多个从库的主库为每一个连接到主库的从库创建一个binlog输出线程,每一个从库都有它自己的I/O线程和SQL线程。

主从复制如图:

image-20210707200351047

image-20210707200447776

步骤一:主库db的更新事件(update、insert、delete)被写到binlog

步骤二:从库发起连接,连接到主库

步骤三:此时主库创建一个binlog dump thread线程,把binlog的内容发送到从库

步骤四:从库启动之后,创建一个I/O线程,读取主库传过来的binlog内容并写入到relay log.

步骤五:还会创建一个SQL线程,从relay log里面读取内容,从Exec_Master_Log_Pos位置开始执行读取到的更新事件,将更新内容写入到slave的db.**

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170317.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月13日 上午8:36
下一篇 2022年8月13日 上午8:46


相关推荐

  • 如何在Centos7 中安装JDK「建议收藏」

    如何在Centos7 中安装JDK「建议收藏」1.先查看是否安装了openjdk(两种方法)①在命令窗口键入:java -version②在命令窗口键入:rpm -qa | grep java2.在物理机下载的jdk安装包,后缀名是rpm3. 安装命令:rpm -ivh jdk-8u171-linux-x64.rpm4.配置JDK环境:vi /etc/profile#set java environmentJAVA_HOME=/usr/jav…

    2022年8月18日
    10
  • VERDI 关于 实用Verdi 的使用技巧

    VERDI 关于 实用Verdi 的使用技巧目录 1 总线拆分 2 统计次数 3 逻辑运算 4 manage rc5 Trace 代码过程中波形窗口保持前置 6 Parameter 提示的默认进制对于做数字集成电路的工程师来说 Verdi 可以说是最常用的代码和波形观察工具了 这里列几个使用中的小技巧 说不上高明 不过自己用着感觉还是蛮有效率的 1 总线拆分分析波形的时候有时候需要把一个多比特的 bus 拆分成几个位宽较小的 bus 以方便观察数值 例如把一个 20 比特的 bus 拆成两个 10 比特的 bus 可以右键点击这个 bus 在弹出的菜

    2026年3月17日
    3
  • Kimi发布技术报告获马斯克点赞,联合创始人杨植麟、吴育昕、周昕宇署名

    Kimi发布技术报告获马斯克点赞,联合创始人杨植麟、吴育昕、周昕宇署名

    2026年3月17日
    2
  • C++中的各种进制转换函数汇总

    C++中的各种进制转换函数汇总一 指定格式输出 nbsp 1 在 C 中 按指定进制格式输出如下 printf 05o n 35 nbsp nbsp nbsp nbsp 按八进制格式输出 保留 5 位高位补零 printf 03d n 35 nbsp nbsp nbsp nbsp 按十进制格式输出 保留 3 位高位补零 printf 05x n 35 nbsp nbsp nbsp nbsp 按十六进制格式输出 保留 5 位高位补零 2 在 C 中 按指定进制格式输出如下 include

    2026年3月17日
    1
  • typescript 接口_4pin接口

    typescript 接口_4pin接口介绍TypeScript的核心原则之一是对值所具有的结构进行类型检查。我们使用接口(Interfaces)来定义对象的类型。接口是对象的状态(属性)和行为(方法)的抽象(描述)接口初探声明接口

    2022年8月7日
    8
  • html5中的空格符

    html5中的空格符html5 中的空格符 nbsp 1 Html 中空格 nbsp nbsp nbsp 不断行的空白 1 个字符宽度 nbsp 半个空白 1 个字符宽度 一个空白 2 个字符宽度 nbsp 窄空白 小于 1 个字符

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号