1.Mysql
- sql语句执行分析
SELECT i.trx_started, -- 开始时间,如果有开始时间超过1分钟的sql需要及时反馈
i.trx_mysql_thread_id, -- 线程号,有紧急需要处理的时候kill这个线程,慎用
p.HOST, -- 机器ip
p.COMMAND , -- 运行状态 -- 主要状态有Query和Sleep,Query表示sql正在执行,Sleep表示sql执行完未提交这个时候要分析应用程序在做什么
p.`TIME` , -- 执行时间 -- 这个执行时间是代表sql执行的真正时间,需要和事务的持续时间区分开来,研发同学可以根据这里判断自己程序当前在做什么
c.SQL_TEXT -- sql语句 -- 5.7的很多情况idle in trans找不到sql,需要从这张表取
FROM INFORMATION_SCHEMA.INNODB_TRX i
left join information_schema.PROCESSLIST p on i.trx_mysql_thread_id = p.ID
left join performance_schema.threads t on i.trx_mysql_thread_id =
t.PROCESSLIST_ID
left join performance_schema.events_statements_current c on c.THREAD_ID =
t.THREAD_ID
order by i.trx_started desc
- 查看死锁
SHOW OPEN TABLES where In_use > 0;
UNLOCK TABLES;
- 查看执行SQL
SHOW PROCESSLIST
-- KILL CONNECTION 48517 --杀进程