欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql 出現(xiàn)故障應用直接中斷連接導致數(shù)據(jù)被鎖(生產故障)詳解

 更新時間:2017年01月13日 08:47:18   投稿:lqh  
這篇文章主要介紹了 Mysql 出現(xiàn)故障應用直接中斷連接導致數(shù)據(jù)被鎖(生產故障)詳解的相關資料,需要的朋友可以參考下

應用直接中斷連接導致數(shù)據(jù)被鎖(生產故障)

  1.  這是一個由應用重啟連接直接而導致數(shù)據(jù)被鎖的問題。
  2.  系統(tǒng)大致結構


基本情況:

  • 整個架構為了統(tǒng)一管理db連接,共享連接。
  • 應用通過loadbalance連接db訪問層。
  • db訪問層后端代理若干db。
  • 應用到loadbalance以mysql協(xié)議通信。
  • db訪問層到db以JDBC方式通信。

故障: 某些數(shù)據(jù)庫中的表數(shù)據(jù)相當長一段時間被鎖,導致應用某些場景失敗。

故障分析:應用開啟一個事務的set autocommit=0命令是從app-lb-db訪問層-db,期間如果某個事務還未執(zhí)行完,而app強行中斷連接,就會導致app-lb的連接斷開,而lb并不直接斷開后端的連接,即lb-db訪問層-db的連接不會斷,從而導致db不會發(fā)生回滾操作。而且此事務對某些記錄加了鎖,于是就會發(fā)生某些數(shù)據(jù)被鎖。直到db訪問層檢測出該連接超過了idle時間才會關閉,并發(fā)送回滾命令給db。

解決問題:

① lb在前端連接關閉時要同時關閉同會話的后端連接,并且db訪問層要監(jiān)聽lb的連接,一旦關閉則要做回滾操作。

②去掉lb,提供客戶端loadbalance,應用一旦關閉連接db訪問層也要關閉連接。

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

最新評論