• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Mysql读写分离过期常用解决方案

    mysql读写分离的坑

    读写分离的主要目标是分摊主库的压力,由客户端选择后端数据库进行查询。还有种架构就是在MYSQL和客户端之间有一个中间代理层proxy,客户端之连接proxy,由proxy根据请求类型和上下文决定请求的分发路由。

    无论使用哪种架构,由于主从可能存在延迟,客户端执行完一个更新事务后马上发起查询,如果查询选择的是从库的话,就有可能读到刚刚的事务更新之前的状态。这种“在从库上会读到系统的一个过期状态”的现象,我们暂且称之为“过期读”。

    方案一:强制走主库方案

    将查询请求分为两类:

    方案二:Sleep方案

    主库更新后,读从库之前先sleep一下,类似执行了select sleep(1)命令,这个方案的假设是,大多数情况下主备延迟在1秒之内,做一个sleep可以有很大概率拿到最新的数据。

    以卖家发布商品为例,商品发布后,用Ajax直接把客户端输入的内容作为“新的商品”显示在页面上,而不是真正地去数据库做查询。这样,卖家就可以通过这个显示,来确认产品已经发布成功了。等到卖家再刷新页面,去查看商品的时候,其实已经过了一段时间,也就达到了sleep的目的,进而也就解决了过期读的问题。

    方案三:判断主备无延迟方案:

    第一种方法:先用show slave status结果里的seconds_behind_master参数的值,可以用来衡量主备延迟时间的长短。先判断这个参数值是否为0,如果不为0,必须等到这个参数变为0才能执行请求。

    第二种方法:对比位点确保主备无延迟。

    如果Master_Log_File和Relay_Master_Log_File、Read_Master_Log_Pos和Exec_Master_Log_Pos这两组值完全相同,就表示接收到的日志已经同步完成。

    第三种方法:对比GTID(全局事物ID)确保主备无延迟

    如果这两个集合相同,表示备库接收到的日志都已经同步完成。

    方案四:等主库位点方案

    select master_pos_wait(file, pos[, timeout]);

    这条命令是在从库执行的 ,参数file和pos指的是主库上的文件名和位置,timeout表示这个函数最多等待N秒。

    如图:先执行trx1,再执行一个查询请求的逻辑,要保证能够查到正确的数据,我们可以使用

    这个逻辑

    1. trx1事物更新完成后,马上执行show master status得到当前主库执行到的File和Position;

    2. 选定一个从库执行查询语句;

    3. 在从库上执行select master_pos_wait(File, Position, 1);

    4. 如果返回值是>=0的正整数,则在这个从库执行查询语句;

    5. 否则,到主库执行查询语句。

    这里我们假设,这条select查询最多在从库上等待1秒。那么,如果1秒内master_pos_wait返回
    一个大于等于0的整数,就确保了从库上执行的这个查询结果一定包含了trx1的数据。

    5到主库执行查询语句,是这类方案常用的退化机制。因为从库的延迟时间不可控,不能无
    限等待,所以如果等待超时,就应该放弃,然后到主库去查。按照我们设定不允许过期读的要求,就只有两种选择,一种是超时放弃,一种是转到主库查询。

    并发连接和并发查询

    innodb_thread_concurrency参数是控制innodb的并发线程上限。一旦超过这个数值,新请求就会进入等待。

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • Springboot + Mysql8实现读写分离功能
    • springboot基于Mybatis mysql实现读写分离
    • 基于mysql+mycat搭建稳定高可用集群负载均衡主备复制读写分离操作
    • PHP实现的mysql读写分离操作示例
    • mysql主从复制读写分离的配置方法详解
    • 利用mycat实现mysql数据库读写分离的示例
    • PHP+MYSQL实现读写分离简单实战
    上一篇:mysql常用备份命令和shell备份脚本分享
    下一篇:Mysql脏页flush及收缩表空间原理解析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Mysql读写分离过期常用解决方案 Mysql,读写,分离,过期,常用,