MySQLinnodb_monitor及死锁检测
showinnodbstatus只是其一种模式的直接展现,并且只能交互式开启,无法自动循环捕获信息innodb状态信息输出到err日志在如何库下都可以,推荐在test数据库下创建
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功能。
不包含独立表空间信息。
我监控采用的是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参数。
本文出自 “My DBA life” 博客,请务必保留此出处

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds



L'article discute de l'utilisation de l'instruction ALTER TABLE de MySQL pour modifier les tables, notamment en ajoutant / abandon les colonnes, en renommant des tables / colonnes et en modifiant les types de données de colonne.

L'article discute de la configuration du cryptage SSL / TLS pour MySQL, y compris la génération et la vérification de certificat. Le problème principal est d'utiliser les implications de sécurité des certificats auto-signés. [Compte de caractère: 159]

L'article traite des stratégies pour gérer de grands ensembles de données dans MySQL, y compris le partitionnement, la rupture, l'indexation et l'optimisation des requêtes.

L'article traite des outils de GUI MySQL populaires comme MySQL Workbench et PhpMyAdmin, en comparant leurs fonctionnalités et leur pertinence pour les débutants et les utilisateurs avancés. [159 caractères]

L'article discute de la suppression des tables dans MySQL en utilisant l'instruction TABLE DROP, mettant l'accent sur les précautions et les risques. Il souligne que l'action est irréversible sans sauvegardes, détaillant les méthodes de récupération et les risques potentiels de l'environnement de production.

L'article discute de la création d'index sur les colonnes JSON dans diverses bases de données comme PostgreSQL, MySQL et MongoDB pour améliorer les performances de la requête. Il explique la syntaxe et les avantages de l'indexation des chemins JSON spécifiques et répertorie les systèmes de base de données pris en charge.

L'article discute de l'utilisation de clés étrangères pour représenter les relations dans les bases de données, en se concentrant sur les meilleures pratiques, l'intégrité des données et les pièges communs à éviter.

L'article discute de la sécurisation MySQL contre l'injection SQL et les attaques brutales à l'aide de déclarations préparées, de validation des entrées et de politiques de mot de passe solides (159 caractères)
