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监控死锁的更多相关文章

  1. 16 利用Zabbix完成windows监控

    点击返回:自学Zabbix之路 16 利用Zabbix完成windows监控 1.安装zabbix_agentd 1.1.下载zabbix_agentd监控客户端软件安装包(windows操作系统客户 ...

  2. 17 利用Zabbix完成VMare监控

    点击返回:自学Zabbix之路 17 利用Zabbix完成VMare监控 最近在研究通过Zabbix监控VMware vSphere,Zabbix Documentation 3.0 从文档中我们看到 ...

  3. SQL Server扩展事件-- 使用system_health默认跟踪会话监控死锁

    SQL Server扩展事件(Extended Events)-- 使用system_health默认跟踪会话监控死锁 转自:http://blog.51cto.com/ultrasql/160037 ...

  4. 利用FileSystemWatcher实现磁盘文件监控

    马上放假了,好开森啊O(∩_∩)O哈哈~ ——————————————————————————————————————————————————————— 昨天逛园子,发现了一个FileSystemWa ...

  5. Linux下利用nc命令来监控检测服务器的端口使用情况(转载)

    最近碰到一个项目,前端用apache htttpd进行发布(80端口),通过双机负载均衡转发到后端的两个tomcat进行处理(8081和8082端口),现在需要随时监控这三个端口的情况,一旦down掉 ...

  6. 利用Windows性能计数器(PerformanceCounter)监控

    一.概述 性能监视,是Windows NT提供的一种系统功能.Windows NT一直以来总是集成了性能监视工具,它提供有关操作系统当前运行状况的信息,针对各种对象提供了数百个性能计数器.性能对象,就 ...

  7. 利用wget 和 curl 监控网站是否正常

    监控网站URL是否正常最常见的方法莫过于wget和curl命令了,这两个命令都是非常强大,参数也非常多,下面列举几个常用的参数. wget  常用命令参数:--spider              ...

  8. zabbix利用自带模板-监控mysql性能

    环境: zabbix3.4.4 mariadb 5.5.56 要求:  利用zabbix 自带的模板 监控mariadb 上的 并发连接数,慢查询数量,增删改查.请求流量带宽,mysql响应流量带宽等 ...

  9. ORA-00060: Deadlock detected 模拟死锁产生与解决方案

    死锁:死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程 ...

随机推荐

  1. Evolutionary Computing: 1. Introduction

    Outline 什么是进化算法 能够解决什么样的问题 进化算法的重要组成部分 八皇后问题(实例) 1. 什么是进化算法 遗传算法(GA)是模拟生物进化过程的计算模型,是自然遗传学与计算机科学相互结合的 ...

  2. CSS Hack大全-教你如何区分出IE6-IE10、FireFox、Chrome、Opera

    CSS Hack大全-教你如何区分出IE6-IE10.FireFox.Chrome.Opera 转载自:http://www.jb51.net/article/50116.htm 现在的浏览器IE6- ...

  3. asp.net页面跳转sessionid会变

    今天发现在一个Asp.net站点中, 同一次登录, 不停刷新页面或者页面跳转, 此时后台Session的SessionID总是变化的. 创建一个页面,添加一个button,后台代码非常简单,如下   ...

  4. 1095: [ZJOI2007]Hide 捉迷藏

    题意:给定一棵树,每个节点可以变成黑白两色.一开始所有节点都是黑色,操作可将点颜色改变,询问当前情况下距离最远的两个黑点的距离. 动态树分治.一开始想的是对于每个节点维护主大和次大,后来发现这实在是太 ...

  5. JAVA https证书相关

    生成证书: keytool -genkey -alias cas -keyalg RSA -keystore  cas.key 导出证书: keytool -export -alias cas  -f ...

  6. vertical-align及IE7下的inline-block

    在IE7下,是不支持inline-block元素的,当对块级元素如dl进行inline-block样式设置时,在IE7浏览器是下样式是不会生效的. 若要在IE7下实现将块级元素设置为内联元素,可以这样 ...

  7. Android Studio下SQLite数据库的配置与使用(完)

    一,AS开发app用,所用的数据库有限制,必须使用较小的SQLite(MySql和Sql Server想想就不显示) 但是该数据库并不需要我们单独下载,安装的SDK中已经有了,在C:\AndroidS ...

  8. Python学习路程day11

    SqlAlchemy ORM SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据A ...

  9. UIImageView变灰

    1.UIImageView圆角 CALayer *l = [cell.imgAvatarImage layer]; [l setMasksToBounds:YES]; [l setCornerRadi ...

  10. 在Hibernate中配置Hilo进行数据绑定测试时出错:org.hibernate.MappingException: Could not instantiate id generator

    在进行学习具体类单表继承时使用hilo类型时总是在调度过程中提示如下信息,无法通过.留下记录备查. 在网上找相关信息, 未解决,详细如下: org.hibernate.MappingException ...