Mysql 出现故障应用直接中断连接导致数据被锁(生产故障)详解

发布时间 - 2026-01-10 22:30:02    点击率:

应用直接中断连接导致数据被锁(生产故障)

  1.  这是一个由应用重启连接直接而导致数据被锁的问题。
  2.  系统大致结构


基本情况:

  • 整个架构为了统一管理db连接,共享连接。
  • 应用通过loadbalance连接db访问层。
  • db访问层后端代理若干db。
  • 应用到loadbalance以mysql协议通信。
  • db访问层到db以JDBC方式通信。

故障: 某些数据库中的表数据相当长一段时间被锁,导致应用某些场景失败。

故障分析:应用开启一个事务的set autocommit=0命令是从app-lb-db访问层-db,期间如果某个事务还未执行完,而app强行中断连接,就会导致app-lb的连接断开,而lb并不直接断开后端的连接,即lb-db访问层-db的连接不会断,从而导致db不会发生回滚操作。而且此事务对某些记录加了锁,于是就会发生某些数据被锁。直到db访问层检测出该连接超过了idle时间才会关闭,并发送回滚命令给db。

解决问题:

① lb在前端连接关闭时要同时关闭同会话的后端连接,并且db访问层要监听lb的连接,一旦关闭则要做回滚操作。

②去掉lb,提供客户端loadbalance,应用一旦关闭连接db访问层也要关闭连接。

 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# Mysql  # 故障中断连接  # 故障中断连接解决办法  # 故障中断连接详解及是解决方案  # MYSQL主从库不同步故障一例解决方法  # 线上MYSQL同步报错故障处理方法总结(必看篇)  # MySQL下高可用故障转移方案MHA的超级部署教程  # 一次MySQL慢查询导致的故障  # MySQL复制的概述、安装、故障、技巧、工具(火丁分享)  # 检测MySQL的表的故障的方法  # mysql 无法联接常见故障及原因分析  # MySQL故障切换笔记之应用无感知设计详解  # 就会  # 后端  # 也要  # 才会  # 是从  # 这是一个  # 希望能  # 还未  # 解决问题  # 谢谢大家  # 重启  # 时要  # 数据库中  # 则要  # 客户端  # 故障分析  # 超过了  # db  # loadbalance  # br 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现用户密码重置功能?(完整流程代码)  如何在Tomcat中配置并部署网站项目?  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  Laravel如何处理表单验证?(Requests代码示例)  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何快速上传自定义模板至建站之星?  Android使用GridView实现日历的简单功能  Laravel如何实现API速率限制?(Rate Limiting教程)  如何续费美橙建站之星域名及服务?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  黑客如何通过漏洞一步步攻陷网站服务器?  JavaScript如何实现音频处理_Web Audio API如何工作?  详解Android——蓝牙技术 带你实现终端间数据传输  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  太平洋网站制作公司,网络用语太平洋是什么意思?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  Mybatis 中的insertOrUpdate操作  郑州企业网站制作公司,郑州招聘网站有哪些?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  浅谈Javascript中的Label语句  Laravel怎么自定义错误页面_Laravel修改404和500页面模板  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  魔方云NAT建站如何实现端口转发?  利用JavaScript实现拖拽改变元素大小  米侠浏览器网页背景异常怎么办 米侠显示修复  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  Java类加载基本过程详细介绍  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  Laravel如何集成Inertia.js与Vue/React?(安装配置)  *服务器网站为何频现安全漏洞?  Laravel如何使用Telescope进行调试?(安装和使用教程)  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  如何在搬瓦工VPS快速搭建网站?  如何彻底删除建站之星生成的Banner?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  中山网站制作网页,中山新生登记系统登记流程?  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  原生JS实现图片轮播切换效果  高性价比服务器租赁——企业级配置与24小时运维服务  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  如何快速搭建高效WAP手机网站?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层  如何在万网开始建站?分步指南解析