php 检测死锁,MySQL 死锁检测

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

logo.gif

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值