利用pt-deadlock-logger监控死锁
Percona提供的percona-toolkit提供很多实用功能,这里着重介绍如何监控死锁.
pt-deadlock-logger基本用法
Usage: pt-deadlock-logger [OPTIONS] DSN
解释:指定DSN死锁信息,它可以标准输出到屏幕也可以记入到表中或者日志文件,OPTIONS就是要加的参数了.
在这里做个模拟产生死锁的试验,例子如下:
session1:
mysql> create table lock1 (id int,name char(20),address varchar(50));
Query OK, 0 rows affected (0.15 sec)
mysql> create table lock2 (id int,name char(20),address varchar(50));
Query OK, 0 rows affected (0.15 sec)
mysql> insert into lock1 values (1,'aa','beijing');
Query OK, 1 row affected (0.00 sec)
mysql> insert into lock1 values (2,'bb','shanghai');
Query OK, 1 row affected (0.02 sec)
mysql> insert into lock1 values (3,'cc','shenzhen');
Query OK, 1 row affected (0.01 sec)
mysql> insert into lock2 values (1,'dd','beijing');
Query OK, 1 row affected (0.01 sec)
mysql> insert into lock2 values (2,'ee','tianjin');
Query OK, 1 row affected (0.01 sec)
mysql> insert into lock2 values (3,'ff','henan');
Query OK, 1 row affected (0.01 sec)
mysql> select * from lock1;
+------+------+----------+
| id | name | address |
+------+------+----------+
| 1 | aa | beijing |
| 2 | bb | shanghai |
| 3 | cc | shenzhen |
+------+------+----------+
3 rows in set (0.01 sec)
mysql> select * from lock2;
+------+------+---------+
| id | name | address |
+------+------+---------+
| 1 | dd | beijing |
| 2 | ee | tianjin |
| 3 | ff | henan |
+------+------+---------+
3 rows in set (0.00 sec)
mysql> set autocommit=0;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from lock1 where id=1 for update;
+------+------+---------+
| id | name | address |
+------+------+---------+
| 1 | aa | beijing |
+------+------+---------+
1 row in set (0.00 sec)
session2
mysql> use test;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> set autocommit=0;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from lock2 where id=1 for update;
+------+------+---------+
| id | name | address |
+------+------+---------+
| 1 | dd | beijing |
+------+------+---------+
1 row in set (0.00 sec)
session1
mysql> select * from lock2 where id=1 for update; ---锁等待
session2
mysql> select * from lock1 where id=1 for update;
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction
OK,已经产生死锁了.现在用pt-deadlock-logger分析一下
[root@localhost ~]# pt-deadlock-logger --run-time=10 --interval=3 --create-dest-table --dest D=test,t=deadlocks u=root,p=xxxxx
server ts thread txn_id txn_time user hostname ip db tbl idx lock_type lock_mode wait_hold victim query
localhost.localdomain 2014-01-23T16:04:02 22 0 100 root localhost test
lock2 GEN_CLUST_INDEX RECORD X w 0 select * from lock2 where id=1 for
update
localhost.localdomain 2014-01-23T16:04:02 23 0 54 root localhost test
lock1 GEN_CLUST_INDEX RECORD X w 1 select * from lock1 where id=1 for
update
参数解释如下:
--create-dest-table : 创建指定信息的表.
--dest : 创建存储死锁信息的表.
--database : -D,指定数据库.
--table : -t,指定表名.
--log : 指定死锁日志信息写入到文件.
--run-time : 运行次数,默认永久.
--interval : 运行间隔时间,默认30s.
--u,p, : 链接数据库的信息.
继续看deadlock表里是否存储信息
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| deadlocks |
| lock1 |
| lock2 |
+----------------+
3 rows in set (0.00 sec)
mysql> select * from deadlocks\G
*************************** 1. row ***************************
server: localhost.localdomai
ts: 2014-01-23 16:04:02
thread: 22
txn_id: 0
txn_time: 100
user: root
hostname: localhost
ip:
db: test
tbl: lock2
idx: GEN_CLUST_INDEX
lock_type: RECORD
lock_mode: X
wait_hold: w
victim: 0
query: select * from lock2 where id=1 for update
*************************** 2. row ***************************
server: localhost.localdomai
ts: 2014-01-23 16:04:02
thread: 23
txn_id: 0
txn_time: 54
user: root
hostname: localhost
ip:
db: test
tbl: lock1
idx: GEN_CLUST_INDEX
lock_type: RECORD
lock_mode: X
wait_hold: w
victim: 1
query: select * from lock1 where id=1 for update
2 rows in set (0.00 sec)
mysql>
测试表明死锁信息已经写入到了表中,记录的是2条导致死锁的SQL还有包括库、用户等等很详细的信息.对于我们可以利用pt-deadlock-logger,查看到底哪些SQL引起死锁方便定位.
利用pt-deadlock-logger监控死锁的更多相关文章
- 16 利用Zabbix完成windows监控
点击返回:自学Zabbix之路 16 利用Zabbix完成windows监控 1.安装zabbix_agentd 1.1.下载zabbix_agentd监控客户端软件安装包(windows操作系统客户 ...
- 17 利用Zabbix完成VMare监控
点击返回:自学Zabbix之路 17 利用Zabbix完成VMare监控 最近在研究通过Zabbix监控VMware vSphere,Zabbix Documentation 3.0 从文档中我们看到 ...
- SQL Server扩展事件-- 使用system_health默认跟踪会话监控死锁
SQL Server扩展事件(Extended Events)-- 使用system_health默认跟踪会话监控死锁 转自:http://blog.51cto.com/ultrasql/160037 ...
- 利用FileSystemWatcher实现磁盘文件监控
马上放假了,好开森啊O(∩_∩)O哈哈~ ——————————————————————————————————————————————————————— 昨天逛园子,发现了一个FileSystemWa ...
- Linux下利用nc命令来监控检测服务器的端口使用情况(转载)
最近碰到一个项目,前端用apache htttpd进行发布(80端口),通过双机负载均衡转发到后端的两个tomcat进行处理(8081和8082端口),现在需要随时监控这三个端口的情况,一旦down掉 ...
- 利用Windows性能计数器(PerformanceCounter)监控
一.概述 性能监视,是Windows NT提供的一种系统功能.Windows NT一直以来总是集成了性能监视工具,它提供有关操作系统当前运行状况的信息,针对各种对象提供了数百个性能计数器.性能对象,就 ...
- 利用wget 和 curl 监控网站是否正常
监控网站URL是否正常最常见的方法莫过于wget和curl命令了,这两个命令都是非常强大,参数也非常多,下面列举几个常用的参数. wget 常用命令参数:--spider ...
- zabbix利用自带模板-监控mysql性能
环境: zabbix3.4.4 mariadb 5.5.56 要求: 利用zabbix 自带的模板 监控mariadb 上的 并发连接数,慢查询数量,增删改查.请求流量带宽,mysql响应流量带宽等 ...
- ORA-00060: Deadlock detected 模拟死锁产生与解决方案
死锁:死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程 ...
随机推荐
- bootstrap笔记-布局
1.通过文本对齐类,可以简单方便的将文字重新对齐. <p class="text-left">Left aligned text.</p> <p cl ...
- MVC部署到iis
程序域功能->打开或关闭->iis信息服务及.net framework下的两个要勾选 1. 发布程序,以文件系统file system 的形式,发布到一个文件夹里 自定义-> ...
- 项目二(业务GO)——跨域上传图片(请求接口)
之前,就听过“跨域上传”图片的问题,只是疏于研究,也就一再搁置,直至今天再次遇见这个不能避免的“坑”,才不得不思考一下,怎么“跨域上传”图片或者文件? 问题来源: 何为“跨域”? ——就是给你一个接口 ...
- BZOJ1996 [Hnoi2010]chorus 合唱队
很容易想到区间DP 然后发现这个区间只和圆序列的最后一个数有关,而原序列的最后一个数只可能是现在区间的头或者尾 令$f[i][j][0/1]$表示在区间$[i, j]$之间,原序列的最后一个数是当前区 ...
- 【转】 linux下的g++编译器安装
再debian下直接apt-get install gcc g++就可以了.按照类似的逻辑,再Fedora下yum install gcc g++ 报告无法找到g++包. 查了一下,原来这个包的名字叫 ...
- python多线程监控指定目录
import win32file import tempfile import threading import win32con import os dirs=["C:\\WINDOWS\ ...
- android技巧(一):如何方便知晓当前Activity?如何管理应用中的Activity?如何最佳的启动一个Activity?
1.如何方便知晓当前Activity? 可以不看代码根据当前界面就知道界面所在Activity的写法: 建立BaseActivity,继承自Activity,在BaseActivity的OnCreat ...
- eclipse安装插件的三种方式
方式一:拷贝安装方式 将下载的插件文件中的plugins 和 features 文件夹直接天骄到eclipse中的plugins 和 features 文件夹中. 方式二:update安装方式 Hel ...
- 从零开始学习Node.js例子五 服务器监听
httpsnifferInvoke.js var http = require('http'); var sniffer = require('./httpsniffer'); var server ...
- Collection(数组、字典、集合)
Collection -NSArray和NSMutableArray +array:创建一个空数组 +arrayWithArray:从另一个数组创建新的数组 ...