zoukankan      html  css  js  c++  java
  • mysql deadlock found when trying to get lock 问题排查

    mysql deadlock found when trying to get lock 问题排查

    1 获 取锁等待情况

    可以通过检查 table_locks_waited和table_locks_immediate状态变量来分析系统上的表锁定争夺:

    mysql> show status like 'Table%';
    +----------------------------+----------+
    | Variable_name | Value |
    +----------------------------+----------+
    | Table_locks_immediate | 105 |
    | Table_locks_waited | 3 |
    +----------------------------+----------+
    2 rows in set (0.00 sec)
    

    2 可以通过检查 Innodb_row_lock状态变量来分析系统上的行锁的争夺情况:

    mysql> show status like 'innodb_row_lock%';
    +----------------------------------------+----------+
    | Variable_name | Value |
    +----------------------------------------+----------+
    | Innodb_row_lock_current_waits | 0 |
    | Innodb_row_lock_time | 2001 |
    | Innodb_row_lock_time_avg | 667 |
    | Innodb_row_lock_time_max | 845 |
    | Innodb_row_lock_waits | 3 |
    +----------------------------------------+----------+
    5 rows in set (0.00 sec)
    

    3 设置监视器

    另外,针对Innodb类型的表,如果 需要察看当前的锁等待情况,可以设置InnoDB Monitors,然后通过Show innodb status察看,设置的方式是:
    CREATE TABLE innodb_monitor(a INT) ENGINE=INNODB;

    监视器可以通过发出下列语句来被停止:
    DROP TABLE innodb_monitor;

    设置监视器后,在show innodb status(高版本使用:show engine innodb status)的显示内容中,会有详细的当前锁等待的信息,包括表名、锁类型、锁定记录的情况等等,便于进行进一步的分析和问题的确定。打开监视器以后,默 认情况下每15秒会向日志中记录监控的内容,如果长时间打开会导致.err文件变得非常的巨大,所以我们在确认问题原因之后,要记得删除监控表以关闭监视 器。或者通过使用--console选项来启动服务器以关闭写日志文件。

    4 查看自己占用的连接

    如果是root帐号,你能看到所有用户的当前连接。如果是其它普通帐号,只能看到自己占用的连接。
    show processlist;只 列出前100条,如果想全列出请使用show full processlist;

    mysql> show processlist;
    
  • 相关阅读:
    章节1:SQL语言简易入门
    章节0:MySQl学前知识储备
    iOS 设置导航栏全透明
    IOS修改Navigation Bar上的返回按钮文本颜色,箭头颜色以及导航栏按钮的颜色
    iOS import导入时没有提示的解决办法
    iOSAPP开发项目搭建
    如何搭建iOS项目基本框架
    UIWebView中JS与OC交互 WebViewJavascriptBridge的使用
    iOS概念之KVO(Key-Value Observing)
    oc调javascript方法(evaluateJavaScript:)&&js给oc发通知
  • 原文地址:https://www.cnblogs.com/rwxwsblog/p/6655552.html
Copyright © 2011-2022 走看看