• 技术文章 >数据库 >mysql教程

    MySQL 死锁检测

    2016-06-07 17:28:27原创995

    对于死锁,MySQL并没有提供提供直接的变量来表示。对于5.5版本之后的performance_shcema可以提供锁的详细信息(但我们还是5.0呢)

    对于死锁,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参数。

    linux

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    千万级数据并发解决方案(理论+实战):点击学习

    Mysql单表千万级数据量的查询优化与性能分析

    Mysql主从原理及其在高并发系统中的应用

    上一篇:Linux 下设置Oracle 11.2 数据库自动启动 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 实例分析MySQL中pt-query-digest工具的使用记录• MySQL存储过程高级SQL语句总结• 深入理解MySQL索引优化器工作原理• 简单聊聊MySQL中join查询• 一起聊聊Mysql两阶段锁和死锁
    1/1

    PHP中文网