DDL期間TDSQL異常會話查詢造成數據庫主備切換

問題描述:

? ? 7*24聯機交易系統,傍晚時分,從客戶端后臺對3千萬行的大表執行縮短varchar類型字段長度的ddl語句,執行期間,為了查看ddl進度,從TDSQL-MySQL赤兔前端頁面點擊異常會話查詢,之后數據庫卡住,發生主備切換,主備切換后的幾分鐘內數據庫交易耗時上升。

問題分析:

? ?查看tdsql記錄的processlist的日志,發現ddl語句之后,就是對performance_schema.data_locks試圖的查詢語句,其余sql語句都阻塞在該data_locks查詢sql后面。點擊查看主備切換原因,是因為心跳檢測中斷時間超過20s,數據庫誤以為主庫掛掉,發起主備切換。

原因總結:

? ? 從客戶端后臺執行ddl語句時,會對全表加行鎖,由于該實例為分布式實例,每一個set行數為500萬行左右。在TDSQL-MySQL赤兔前端頁面點擊異常會話查詢,會使用到performance_schema.data_locks視圖,查詢data_locks視圖時,首先需要獲取trx_sys->mutex這個信號量,獲取到trx_sys->mutex后掃描trx_sys結構下面trx_lock_list和mysql_lock_list兩個記錄鎖信息的雙向鏈表,當掃描到執行ddl語句的表的鎖信息時,要等把這個表的所有行鎖信息掃描完后才會釋放trx_sys->mutex互斥量,掃描時間過長造成trx_sys->mutex長時間未釋放。其他dml語句在執行時,也需要申請trx_sys->mutex互斥量,向trx_sys結構中的事務鏈表注冊一個事務。但data_locks視圖異常會話持有的trx_sys->mutex長時間未釋放,使得其余dml語句獲取不到trx_sys->mutex被阻塞,這其中就包括心跳檢測的dml語句,心跳檢測sql中斷超過20s,TDSQL數據庫認為主庫掛掉,發起主備切換。

解決方案:

? ? 1、執行ddl時,避開業務高峰期。

? ? 2、從赤兔前端執行ddl操作,使用到pt工具執行online ddl。

? ? 3、執行ddl語句時,謹慎使用異常會話查詢功能。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/90636.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/90636.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/90636.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

弧焊機器人氣體全方位節能指南

氬弧焊(TIG焊接)作為其中一種高效且精密的技術,憑借其穩定性和高質量的焊接效果,在航空航天、汽車制造、船舶建造以及石油化工等領域占據了不可或缺的地位。氬弧焊通過使用惰性氣體(如氬氣)保護電弧和熔池&…

數據清洗(ETL/ELT)原理與工具選擇指南:企業數字化轉型的核心引擎?

目錄 一、數據清洗(ETL/ELT)到底在干啥? 1.揪出并處理異常值 2.把缺失的數據補上(或處理好) 3.數據轉換與標準化 4.一致性校驗 二、工具怎么選?看菜吃飯,量體裁衣 1.數據量不大、要求不高…

阿里云服務器,CentOS7.9上安裝YApi 接口管理平臺

目錄 1.node安裝 1.1下載node,解壓 1.2 部署bin文件 1.3 安裝mongodb 2.啟動yapi 2.1 前置命令 2.2 啟動服務 3.利用pm2方便服務管理維護 3.1.安裝pm2 3.2 常用 PM2 命令 4.常見問題 4.1. 確認 MongoDB 是否安裝 4.2. 安裝 MongoDB(若未安裝&#xff…

阿里云錯題集分享

有最近想要考試阿里云的可以私信我 ,一起加油錯題集1.在使用阿里云的負載均衡SLB實例時,做了如下健康檢查的配置:成功響應和超時響應時間均為1秒,健康檢查間隔為2秒,不健康閾值為3,健康閾值為3。即對于確認一個云服務器…

Android 12 - 部分相機橫屏顯示方案

1.相機過渡界面方向旋轉 Android 10 - 相機過渡界面默認角度 同A10 有些區別,再次增加記錄修改。 這個文件沒有修改,只是說明 src/com/android/camera/CameraActivity.javaprivate void freezeScreenCommon(boolean async) {long startTime System.…

Operation Blackout 2025 Phantom Check hayabusa+ControlSet001+VirtualBox

QAQA攻擊者使用哪個 WMI 類來檢索型號和制造商信息以進行虛擬化檢測?Win32_ComputerSystem攻擊者執行了哪個 WMI 查詢來檢索計算機的當前溫度值?SELECT CurrentTemperature FROM MSAcpi_ThermalZoneTemperature攻擊者加載了 PowerShell 腳本以檢測虛擬化…

《O-PAS?標準的安全方法》白皮書:為工業自動化系統筑起安全防線

The Open Group 最新白皮書《O-PAS?標準的安全方法》重磅發布,為流程工業在邁向開放架構與多供應商互操作的過程中,指明了安全實踐的方向。O-PAS?標準的安全方法ABOUT PUBLICATION亮點一:首次系統闡釋 O-PAS? 標準安全方法與 IEC/ISA 6244…

UML 圖類型全解析:結構圖與行為圖分類詳解

作為軟件架構的核心建模語言,UML(統一建模語言)通過14種標準圖表提供系統多維度視角。這些圖表分為結構圖(靜態模型) 和 行為圖(動態模型) 兩大類,覆蓋從需求到實現的完整生命周期。…

lodash不支持 Tree Shaking 而 lodash-es可以

lodash 無法有效支持 Tree Shaking 而 lodash-es 可以,核心區別在于?模塊規范、文件結構和靜態分析兼容性?。以下是具體原因分析: ?? 一、模塊規范差異(核心原因) lodash(CommonJS 規范)? 使用 requir…

java+vue+SpringBoo高校實習信息發布網站(程序+數據庫+報告+部署教程+答辯指導)

源代碼數據庫LW文檔(1萬字以上)開題報告答辯稿ppt部署教程代碼講解代碼時間修改工具 技術實現 開發語言:后端:Java 前端:vue框架:springboot數據庫:mysql 開發工具 JDK版本:JDK1.8 數…

uniApp實戰五:自定義組件實現便捷選擇

文章目錄1.最終效果預覽2.快速選擇組件封裝3.彈框組件封裝4.組件邏輯實現5.組件樣式6.頁面引入1.最終效果預覽 2.快速選擇組件封裝 <uv-cell :border"isShowBorder"><template v-slot:title><text class"title-key">{{ title }}</te…

AI在垂直領域的深度應用:醫療、金融與自動駕駛的革新之路

AI在垂直領域的深度應用:醫療、金融與自動駕駛的革新之路 一、醫療領域:AI驅動的精準診療與效率提升 1. 醫學影像診斷 AI算法通過深度學習技術,已實現對X光、CT、MRI等影像的快速分析,輔助醫生檢測癌癥、骨折等疾病。例如,Google DeepMind的AI系統在乳腺癌篩查中,誤檢率…

模塊三:現代C++工程實踐(4篇)第二篇《性能調優:Profile驅動優化與匯編級分析》

性能調優&#xff1a;Profile驅動優化與匯編級分析實戰&#xff1a;優化矩陣乘法至SSE/AVX指令集&#xff08;終極加強版&#xff09;一、性能瓶頸的全鏈路診斷&#xff08;深度擴展&#xff09;1.1 硬件性能計數器的極致利用PMU事件深度定制&#xff1a;# 捕獲L1緩存事件與分支…

二刷 黑馬點評 商戶查詢緩存

緩存 數據交換的緩沖區&#xff0c;俗稱的緩存是緩沖區內的數據&#xff0c;一般從數據庫中獲取&#xff0c; 例1:Static final ConcurrentHashMap<K,V> map new ConcurrentHashMap<>(); 本地用于高并發例2:static final Cache<K,V> USER_CACHE CacheBuild…

【前端】【組件庫開發】【原理】【無框架開發】現代網頁彈窗開發指南:從基礎到優化

效果 現代網頁彈窗開發指南&#xff1a;從基礎到優化 彈窗&#xff08;Modal&#xff09;作為網頁交互的重要組件&#xff0c;在用戶通知、確認操作和表單輸入等場景中廣泛應用。本文將循序漸進地講解彈窗的技術實現與最佳實踐。 一、彈窗基礎概念 彈窗是一種覆蓋在主內容之…

【操作系統】線程

JavaEE—線程 一、進程與線程 1.包含管理 2.資源布局 2.1公共資源 2.2私有資源 二、并發編程 1.多線程優勢 1.1創建 1.1.1多線程 1.1.2多進程 1.2通信 1.2.1多線程 1.2.2多進程 1.3調度 1.3.1多線程 1.3.2多進程 1.4銷毀 1.4.1多線程 1.4.2多進程 2.多進程…

React 自定義Hook——頁面或元素滾動到底部監聽 Hook

功能簡介 useReachBottom 是一個 React 自定義 Hook&#xff0c;支持監聽頁面&#xff08;body&#xff09;或任意可滾動元素&#xff08;如 div&#xff09;是否滾動到底部。它能幫助你在用戶滑動到底部時觸發加載更多、顯示提示等操作&#xff0c;極大提升前端交互體驗。 亮…

當Powerbi遇到quickbi,性能優化方式對比

powerbi性能優化對于powerbi&#xff0c;性能優化可以從15個方面考慮&#xff1a; 1.過濾源數據【quickbi數據集過濾或sql過濾】2.刪除無關列 【quickbi不選字段或sql不查詢】3.聚合分析粒度 【quickbi使用sql聚合或計算字段聚合】4.整理字段 【quickbi使用sql聚合或計算字段聚…

ValueConverter轉換器WPF

屬性搭橋 比如BoolToVisibility 創建兩個屬性 Bool Visibility 這樣不好 混亂了viewmodels 降低了泛用性系統自帶的convertor <Window.Resources><BooleanToVisibilityConverter x:Key"booltovis"></BooleanToVisibilityConverter><…

Qt數據庫編程詳解:SQLite實戰指南

Qt數據庫編程詳解&#xff1a;SQLite實戰指南 目錄 SQLite數據庫簡介Qt數據庫核心類數據庫操作全流程CRUD操作實戰運行效果展示 1. SQLite數據庫簡介 SQLite是Qt內置的輕量級嵌入式數據庫&#xff1a; #mermaid-svg-OiZ2cgq9n1G69iH5 {font-family:"trebuchet ms",…