Skip to content

Zeroplex 生活隨筆

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

Deadlock Wait Timeout Exceeded on MySQL

Posted on 2022 年 4 月 13 日2022 年 4 月 13 日 By 日落 在〈Deadlock Wait Timeout Exceeded on MySQL〉中尚無留言

遇到 MySQL 的「deadlock wait timeout exceeded」,可以參考「Lock wait timeout exceeded; try restarting transaction」的說明。

尚未找到造成此問題的 query,暫時的解決辦法是:

  • 暫時先將 innodb_lock_wait_timeout 的值調大 (注意:不是 wait_timeout 這個參數)
  • 記錄導致 transaction 花掉太多時間的 query
    • long_query_time = 10
    • log_queries_not_using_indexes 記錄沒有使用到 index 的 query (這類 query 可能導致 table scan 而花掉超多的時間)

在蒐集 log 的期間,可以先去看一下 table schema,看看是不是有哪一些 column 或 combined index 怪怪的,跑 EXPLAIN 確定一下 index 是不是真的有用到

Tags:MySQL

文章導覽

Previous Post: Apt through Socks proxy
Next Post: Laravel Migration 出現 foreign key constraint in complete 注意事項

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 小提琴 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.

Go to mobile version