码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mysql 45讲学习笔记(二十五)MYSQL保证高可用


    一.最终一致性

    • 只要主库执行更新生成的所有binlog都会被传送到备库并被正确的执行
    • 备库能达到主库一致的状态

    二.主备延迟

       1.同步延迟

    • 主库A执行完成一个事务,写入binlog,这时我们把这个时刻记为T1;
    • 传给备库B,我们把备库B接收完这个binlog的时刻记为T2;
    • 备库B执行完成这个事务,我们把这个时刻记为T3

    主备延迟:同一个事务,在备库执行完成的时间和主库执行完成的时间之差----T3-T1

     2.show salve status命令

    备库执行show slave status命令,返回结果显示seconds_behind_master,表示当前备库延迟了多少秒

    3.seconds_behind_master计算方法

    • 每个事务的binlog里面都有一个时间字段,用于记录主库上写入的时间;
    • 备库取出当前正在执行的事务的时间字段的值,计算它与当前系统时间的差值

    三.导致主备延迟的来源

    1. 备库机器性能比主库差可能导致主备延迟

    2. 备库上做统计分析与查询消耗了大量的CPU资源                                                                   解决方案:

    • 一主多从:多连接从库分担读的压力
    • binlog输出到外部系统,比如Hadoop系统,让外部系统提供统计类查询的能力

       3.大事务

    四.可靠性优先策略

    • 判断备库B现在的second_behind_master,如果小于5s就继续,否则重试
    • 把主库A改成只读状态,把readonly设置为true
    • 判断备库B的second_behind_master的值,直到值变为0(保持可靠性---需要足够小,因为此时不可用)
    • 把备库B改为可读写状态,也就是readonly设置为false;
    • 将业务请求切换为备库B

    五.可用性优先策略

    • 将步骤4 把备库B改为可读写状态,也就是readonly设置为false;
    • 步骤5  将业务请求切换为备库B
    • 直接执行不等数据同步一致

    缺点:

       数据不一致

    • 在满足数据可靠性的前提下,MYAQL高可用系统的可用性,是依赖主备延迟的

    • 延迟时间越小,在主库故障服务恢复时间越短可用性越高

  • 相关阅读:
    二十三种设计模式-解密状态模式:优雅地管理对象状态
    Dell戴尔笔记本外星人Alienware x15 R2原装出厂Windows11系统21H2
    vue如何打包上传至服务器?
    upf低功耗的一个简单的例子
    【大模型 数据增强】IEPILE:基于模式的指令生成解法,提高大模型在信息抽取任务上的性能
    基于Velero1.8.1+Minio实现备份恢复K8s集群
    Baklib帮助中心:自助服务指南
    计算机二级WPS 选择题(模拟和解析七)
    因JVM OOM而进行JVM 垃圾回收器调优更换的一次案例 -ParallelGC和ConcMarkSweepGC
    LTE MAC 层1
  • 原文地址:https://blog.csdn.net/weixin_42369687/article/details/126064931
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号