MySQL 死锁检测

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

  对于死锁,MySQL并没有提供提供直接的变量来表示。对于5.5版本之后的performance_shcema可以提供锁的详细信息(但我们还是5.0呢),对于InnoDB自带的监控器 Innodb_lock_monitor 其输出总是输出到错误日志中,不方便进行对比。

    我监控采用的是zabbix,采用agent 被动方式向zabbix server传送数据。脚本为shell,采用show innodb status 重定向

    核心代码:

    
   检测是否为新的死锁信息:
   New_deadlock() {
    new_line_tile=$(grep -n "LATEST DETECTED DEADLOCK" $1 | cut -d ':' -f 1)
    new_line_time=$(echo "$new_line_tile + 2" | bc) 
    last_dect_time="$(head -n $new_line_time $1 | tail -n 1) ###截取死锁发生的时间戳
    
    [ -e $2 ] || cp $1 $2 #拿这次输出信息,和上次输出信息对比;如果是第一次检测,将这次输出信息cp作为上次输出信息
 
    old_line_tile=$(grep -n "LATEST DETECTED DEADLOCK" $2 | cut -d ':' -f 1)
 
    if [ -z $old_line_tile ];then
      echo 1
      mv $1   $2   ##判断上次输出是否为死锁,不是的话,直接返回1 表明最近一次是新的死锁。并将 此次输出信息重命名
      exit 1
   else      ##否则对比两次的时间戳
      old_line_time=$(echo "$old_line_tile + 2" | bc)   
      old_last_dect_time="$(head -n $old_line_time  $2 | tail -n 1)"
      mv $1   $2 #输出信息为下一次检测做准备
 
      if [ "$last_dect_time" = "$old_last_dect_time" ];then
         echo 0
      else
         cp $1 /tmp/$1_detail #已判定为死锁,需要保留作案信息
         echo 1
      fi
   fi
}

deadlock_check() {
   case $1 in
   1)
    $MYSQL_BIN -u $user -p$password  -S $SOC1 -e "show engine innodb status\G" > /tmp/innodb_status_1_$dthm
    have_dead_lock=$(grep -c  "LATEST DETECTED DEADLOCK" /tmp/innodb_status_1_$dthm)
    #判断这次检测是否包含死锁信息,包含的话 让 New_dead_lock 做死锁对比否则 返回0
    if [ $have_dead_lock -gt 0 ];then
       New_deadlock /tmp/innodb_status_1_$dthm /tmp/innodb_status_1_$dt
    else
       echo 0
    fi;;
  2)
    $MYSQL_BIN -u $user -p$password  -S $SOC2 -e "show engine innodb status\G" > /tmp/innodb_status_2_$dthm
    have_dead_lock=$(grep -c  "LATEST DETECTED DEADLOCK" /tmp/innodb_status_2_$dthm)
    if [ $have_dead_lock -gt 0 ];then
       New_deadlock /tmp/innodb_status_2_$dthm /tmp/innodb_status_2_$dt
    else
       echo 0
    fi;;
  3)
    $MYSQL_BIN -u $user -p$password  -S $SOC3 -e "show engine innodb status\G" > /tmp/innodb_status_3_$dthm
    have_dead_lock=$(grep -c  "LATEST DETECTED DEADLOCK" /tmp/innodb_status_3_$dthm)
    if [ $have_dead_lock -gt 0 ];then
       New_deadlock  /tmp/innodb_status_3_$dthm /tmp/innodb_status_3_$dt
    else
       echo 0
    fi;;
  4)
    $MYSQL_BIN -u $user -p$password  -S $SOC4 -e "show engine innodb status\G" > /tmp/innodb_status_4_$dthm
    have_dead_lock=$(grep -c  "LATEST DETECTED DEADLOCK" /tmp/innodb_status_4_$dthm)
    if [ $have_dead_lock -gt 0 ];then
       New_deadlock /tmp/innodb_status_4_$dthm /tmp/innodb_status_4_$dt
    else
       echo 0
    fi;;
  *)
    echo $ERROR
    exit 1;;
  esac
} 

case  $1中的变量是针对不同机器上多个实例的情况,传送socket参数。






本文转自 位鹏飞 51CTO博客,原文链接:http://blog.51cto.com/weipengfei/1180828,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8月前
APK检测管理系统 毕业设计 JAVA+Vue+SpringBoot+MySQL(二)
APK检测管理系统 毕业设计 JAVA+Vue+SpringBoot+MySQL
|
11天前
|
存储 SQL 关系型数据库
【MySQL技术内幕】6.5-锁问题、阻塞、死锁、锁升级
【MySQL技术内幕】6.5-锁问题、阻塞、死锁、锁升级
37 2
|
1月前
|
存储 监控 关系型数据库
【MySQL】InnoDB 什么情况下会产生死锁
【MySQL】InnoDB 什么情况下会产生死锁
|
1月前
|
关系型数据库 MySQL 中间件
【MySQL实战笔记】07 | 行锁功过:怎么减少行锁对性能的影响?-02 死锁和死锁检测
【4月更文挑战第19天】在高并发环境下,死锁发生在多个线程间循环等待资源时,导致无限期等待。MySQL中,死锁可通过`innodb_lock_wait_timeout`参数设置超时或`innodb_deadlock_detect`开启死锁检测来解决。默认的50s超时可能不适用于在线服务,而频繁检测会消耗大量CPU。应对热点行更新引发的性能问题,可以暂时关闭死锁检测(风险是产生大量超时),控制并发度,或通过分散记录减少锁冲突,例如将数据分拆到多行以降低死锁概率。
36 1
|
1月前
|
弹性计算 关系型数据库 MySQL
检测MySQL 服务是否存活
【4月更文挑战第29天】
16 0
|
1月前
|
弹性计算 关系型数据库 MySQL
检测MySQL 数据库连接数量
【4月更文挑战第29天】
13 0
|
1月前
|
弹性计算 关系型数据库 MySQL
检测 MySQL 服务是否存活
【4月更文挑战第28天】
16 0
|
1月前
|
弹性计算 关系型数据库 MySQL
检测 MySQL 数据库连接数量
【4月更文挑战第28天】
17 0
|
1月前
|
SQL 关系型数据库 MySQL
MySQL又死锁了
MySQL又死锁了
13 0
|
1月前
|
SQL 关系型数据库 MySQL
MySQL事务原理分析(ACID特性、隔离级别、锁、MVCC、并发读异常、并发死锁以及如何避免死锁)
MySQL事务原理分析(ACID特性、隔离级别、锁、MVCC、并发读异常、并发死锁以及如何避免死锁)
121 1