亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

MySQLinnodb_monitor及死鎖檢測

標簽:
MongoDB MySQL


show innodb status只是其一种模式的直接展现,并且只能交互式开启,无法自动循环捕获信息

innodb状态信息输出到 err 日志   在如何 库 下都可以,推荐在 test  数据库下创建如下表

mysql> create table innodb_monitor(a int) engine=innodb;

Query OK, 0 rows affected (0.09 sec)

mysql> create table innodb_tablespace_monitor(a int) engine=innodb;

Query OK, 0 rows affected (0.12 sec)

mysql> create table innodb_lock_monitor(a int) engine=innodb;

Query OK, 0 rows affected (0.13 sec)

mysql> create table innodb_table_monitor(a int) engine=innodb;

Query OK, 0 rows affected (0.09 sec)

创建表后innodb会每过15秒输出一次innodb状态信息到error log,通过删除表停止该monitor功能。

innodb_monitor:实际上就是show engine  innodb status\G

innodb_lock_monitor:和innodb_monitor差不多,但还会有更多关于锁的信息

innodb_table_monitor:系统中所有innodb的表的一些结构和内部信息输出

innodb_tablespace_monitor:输出的是tablespace的信息,注意该monitor输出的只是共享表空间的信息

不包含独立表空间信息。

对于死锁,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博客作者smart818的原创作品,如需转载,请注明出处,否则将追究法律责任

MySQLinnodb_monitor死锁检测mysql


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消