mysql 死锁排查

1、当出现事务执行阻塞时,首先想到查询当前MySQL进程状态:

SHOW FULL PROCESSLIST;

2、查看当前的死锁线程id和导致的sql

SELECT * FROM PERFORMANCE_SCHEMA.events_statements_current

3、条件允许复制可以直接使用这个sql,清晰的打印sql

SELECT
    a.trx_id,
    d.SQL_TEXT,
    a.trx_state,
    a.trx_started,
    a.trx_query,
    b.ID,
    b.USER,
    b.DB,
    b.COMMAND,
    b.TIME,
    b.STATE,
    b.INFO,
    c.PROCESSLIST_USER,
    c.PROCESSLIST_HOST,
    c.PROCESSLIST_DB 
FROM
    information_schema.INNODB_TRX a
    LEFT JOIN information_schema.PROCESSLIST b ON a.trx_mysql_thread_id = b.id 
    AND b.COMMAND = 'Sleep'
    LEFT JOIN PERFORMANCE_SCHEMA.threads c ON b.id = c.PROCESSLIST_ID
    LEFT JOIN PERFORMANCE_SCHEMA.events_statements_current d ON d.THREAD_ID = c.THREAD_ID;

4、information_schema 三剑客

在InnoDB1.0版本之前,用户只能通过命令 SHOW FULL PROCESSLIST,SHOW ENGINE INNODB STATUS等来查看当前数据库中锁的请求,然后再判断事务锁的情 况。从 InnoDB11.0开始,在 INFORMATIONSCHEMA架构下添加了表 INNODB_TRX、 INNODB LOCKS、 INNODB LOCK_WATS。通过这三张表,用户可以更简单地监控当 前事务并分析可能存在的锁问题。

只记录行锁和表锁,而因为线上dll修改表结构导致的阻塞问题不会被记录

1、查询正在活跃的事务
SELECT * FROM information_schema.INNODB_TRX

1、trx_id innodb存储引擎内部唯一的事务id
2、trx_state 事务状态,枚举值(RUNNING、LOCK)
3、trx_started 事务开始时间
4、trx_requested_lock_id
5、trx_wait_started
6、trx_weight
7、trx_mysql_thread_id事务线程id(使用kill值即可杀死该事务)
8、trx_query:事务执行的语句
9、trx_operation_state:事务的当前操作如果有的话否则为null
10、trx_tables_in_use:innodb表的数据用于当处理当前的sql语句
11、trx_tables_locked:innodb表的数量当前sql语句有行锁在上面(因为那些是行锁,不是表锁,表仍旧可以读取和写入通过多个事务m尽管一些记录被锁定)

12、trx_lock_structs:事务保留的锁的数量
13、trx_lock_memory_bytes:这个事务在内存中lock结构占据的大小
14、trx_rows_locked:这个事务锁定的记录。使用 INSERT into SELECT指定的原表会逐渐对表中所有记录添加共享锁,这个值会从0开始增加到总记录数
15、trx_rows_modified:此事务中修改和插入记录的数目
16、trx_concurrency_tickets
17、trx_isolation_level当前事务的隔离级别
18、trx_unique_checks
19、trx_foreign_key_checks
20、trx_last_foreign_key_error
21、trx_adaptive_hash_latched
22、trx_adaptive_hash_timeout
23、trx_is_read_only 是否为只读事务 0不是 1是
24、trx_autocommit_non_locking

2、查看持有锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; 
image.png

1、lock_id 锁的ID
2、lock trx_id 事务ID
3、lock_mode 锁的模式 ,可以取值为 X 、 S、GAP
4、lock_type 锁的类型,表锁还是行锁
5、lock table 要加锁的表
6、lock index 锁住的索引
7、lock_space 锁对象的 space id
8、lockpage 事务锁定页的数量。若是表锁,则该值为NULL
9、lock rec 事务锁定行的数量,若是表锁,则该值为NULL
10、lock data 事务锁定记录的主键值,若是表锁,则该值为NULL

3、查询等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

1、requesting trx id 申请锁资源的事务ID
2、 blocking trx id 阻塞的事务ID
3、requesting_ lock _id 申请的锁的ID
4、 blocking trx id 阻塞的锁的ID

SELECT
    r.trx_id waiting_trx_id,
    r.trx_mysql_thread_id waiting_thread,
    r.trx_query waiting_query,
    b.trx_id blocking_trx_id,
    b.trx_mysql_thread_id blocking_thread,
    b.trx_query blocking_query 
FROM
    information_schema.innodb_lock_waits w
    INNER JOIN information_schema.innodb_trx b ON b.trx_id = w.blocking_trx_id
    INNER JOIN information_schema.innodb_trx r ON r.trx_id = w.requesting_trx_id;
image.png

waiting_query 是当前等到锁的事务发出的阻塞sql
blocking_query 则是阻塞sql阻塞等待的未提交的sql

5、查看事务和mysql连接用户对应关系

SELECT
    * 
FROM
    information_schema.PROCESSLIST p
    LEFT JOIN information_schema.INNODB_TRX t ON p.id = t.trx_mysql_thread_id

6、查看被锁住表

mysql查看被锁住的表,查询是否锁表
show OPEN TABLES where In_use > 0;

7、查看innodb引擎的运行时信息

show engine innodb status;

查看造成死锁的sql语句,分析索引情况,然后优化sql语句;
查看服务器状态
show status like '%lock%';
查看超时时间:
show variables like '%timeout%';

8、杀死事务所在线程/活跃mysql连接

kill trx_tread_id

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352