首頁 > 資料庫 > mysql教程 > MySQL出現Waiting for table metadata lock異常如何解決

MySQL出現Waiting for table metadata lock異常如何解決

WBOY
發布: 2023-05-29 11:31:12
轉載
2614 人瀏覽過

1. 出現原因

執行DDL語句時,會自動為該表加上MDL元資料write鎖定,直到交易提交後才會釋放鎖定。此鎖的作用是為了保護 表結構的完整性、元資料的一致性 。

2. 處理方式

模式一下生產環境如下圖所示: session A 開啟了一個交易並且執行DQL

MySQL出現Waiting for table metadata lock異常如何解決

此時session B 需要對此表的兩個欄位新增全文索引 

MySQL出現Waiting for table metadata lock異常如何解決

#執行後發現一直卡主 

MySQL出現Waiting for table metadata lock異常如何解決

##查看相關的進程清單發現一直在等待獲取mdl 元資料鎖定

select * from information_schema.processlist where info like '%alter table `bas_business_type_text` %'
登入後複製

MySQL出現Waiting for table metadata lock異常如何解決

#查看表鎖定情況可以看到讀寫鎖定互斥了

SELECT * FROM sys.schema_table_lock_waits
登入後複製

MySQL出現Waiting for table metadata lock異常如何解決

據提示執行kill 11 

MySQL出現Waiting for table metadata lock異常如何解決

#可以看到session B 立刻執行成功

MySQL出現Waiting for table metadata lock異常如何解決

################################################################

以上是MySQL出現Waiting for table metadata lock異常如何解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板