Mysql数据库——阻塞语句查询与分析

目录

前言

阻塞语句查询与分析

Show Processlist——查看每个与数据库连接的session状态

非Sleeping状态进程数

执行时间较长进程号

查看当前运行的所有事务

当前锁

被blocking阻塞的事务数

数据库连接数

查看锁状态

正在被使用的表


前言

MySQL阻塞是指并发访问时,某个事务长时间占用资源不释放,导致其他事务受阻或执行缓慢。这可能导致性能下降甚至死锁,需及时处理。阻塞原因主要有锁冲突、长事务和死锁。排查阻塞语句可通过查看进程列表、使用性能监控工具、启用慢查询日志等方法,进而优化查询和索引,调整隔离级别和锁策略。

阻塞语句查询与分析

Show Processlist——查看每个与数据库连接的session状态

# 展示前100条线程
show processlist;
# 如果想列出全部线程,请使用
show full processlist;
mysql> show processlist;
+----+------+-----------+------+---------+------+----------+------------------+
| Id | User | Host      | db   | Command | Time | State    | Info             |
+----+------+-----------+------+---------+------+----------+------------------+
| 15 | root | localhost | NULL | Query   |    0 | starting | show processlist |
+----+------+-----------+------+---------+------+----------+------------------+
1 row in set (0.00 sec)
字段列含义
IdID标识;要kill一个语句的时候用
User当前连接用户
Host显示这个连接从哪个ip的哪个端口上发出
db使用的数据库名
Command连接状态,一般是休眠(sleep);查询(query);连接(connect);
Time连接持续时间;单位是秒
State显示当前sql语句的状态
Info显示这个sql语句

非Sleeping状态进程数

select count(1) from information_schema.processlist where command != 'Sleep'

执行时间较长进程号

select id,time from information_schema.processlist order by time desc limit 5;

查看当前运行的所有事务

select * from information_schema.innodb_trx;

当前锁

# 当前的锁
Mysql8.0 之前使用:select * from information_schema.innodb_locks;
Mysql8.0 使用:select * from performance_schema.data_locks;

# 锁等待的对应关系 
Mysql8.0 之前使用:select * from information_schema.innodb_lock_waits;
Mysql8.0 使用:select * from performance_schema.data_lock_waits;

被blocking阻塞的事务数

SELECT COUNT(BLOCKING_ENGINE_TRANSACTION_ID) FROM performance_schema.data_lock_waits;

数据库连接数

SHOW STATUS LIKE 'Threads_connected';

查看锁状态

show status like 'innodb_row_lock_%';
mysql> show status like'innodb_row_lock_%';
+-------------------------------+-------+
| Variable_name                 | Value |
+-------------------------------+-------+
| Innodb_row_lock_current_waits | 0     |
| Innodb_row_lock_time          | 0     |
| Innodb_row_lock_time_avg      | 0     |
| Innodb_row_lock_time_max      | 0     |
| Innodb_row_lock_waits         | 0     |
+-------------------------------+-------+
5 rows in set (0.01 sec)
字段列含义
Innodb_row_lock_current_waits当前等待锁的数量
Innodb_row_lock_time系统启动到现在,锁定的总时间长度
Innodb_row_lock_time_avg每次平均锁定的时间
Innodb_row_lock_time_max最长一次锁定时间
Innodb_row_lock_waits系统启动到现在总共锁定的次数

正在被使用的表

show OPEN TABLES where In_use > 0;

如果某个事务已经卡住了,可以使用 MySQL的 kill 命令来强制结束该事务,以释放资源。

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是MySQL数据库查询所有语句命令: 1. SELECT:用于从数据库中检索数据。 2. FROM:用于指定要检索数据的表。 3. WHERE:用于筛选数据。 4. GROUP BY:用于将数据分组。 5. HAVING:用于筛选分组后的数据。 6. ORDER BY:用于按指定条件对数据进行排序。 7. JOIN:用于将两个或多个表中的行合并。 8. UNION:用于将两个或多个 SELECT 语句的结果集合并到单个结果集中。 9. LIMIT:用于限制结果集的数量。 10. IN:用于指定一组可能的值。 11. LIKE:用于搜索与指定模式匹配的值。 12. NOT:用于否定条件。 13. EXISTS:用于检查子查询是否有结果。 14. BETWEEN:用于指定一个范围。 15. NULL:用于检查值是否为空。 16. AS:用于为列或表指定别名。 17. AVG:用于计算列的平均值。 18. COUNT:用于计算列的行数。 19. MAX:用于查找列中的最大值。 20. MIN:用于查找列中的最小值。 21. SUM:用于计算列的总和。 ### 回答2: MySQL数据库查询所有语句命令主要包括以下几个常用的命令: 1. SELECT:用于从数据库中检索数据。可以根据指定的条件和要求来选择需要的列和行。 2. INSERT INTO:用于将新的数据插入到数据库中的表中。 3. UPDATE:用于更新数据库表中的已有数据。 4. DELETE:用于从数据库表中删除数据。 5. CREATE TABLE:用于创建一个新的数据库表。 6. ALTER TABLE:用于修改已有的数据库表的结构,例如添加、删除或修改列。 7. DROP TABLE:用于删除数据库表。 8. TRUNCATE TABLE:用于删除数据库表中的所有数据,但保留表的结构。 9. USE:用于选择要操作的数据库。 10. SHOW DATABASES:用于查看当前MySQL服务器上的所有数据库。 11. SHOW TABLES:用于查看当前数据库中的所有表。 12. DESC(或DESCRIBE):用于查看表的结构和字段的详细信息。 13. SHOW INDEX:用于显示表的索引信息。 14. SHOW PROCEDURE STATUS:用于显示当前数据库中的存储过程的状态。 15. SHOW VARIABLES:用于查看和修改MySQL服务器的变量。 这些是MySQL数据库查询中常用的命令,不同的命令可以用于不同的查询和操作需求。可以根据具体的业务需求选择合适的命令进行操作。 ### 回答3: MySQL数据库查询所有语句命令包括SELECT、SHOW、DESCRIBE和EXPLAIN等。它们是用来检索和展示数据库中存储的数据和表结构的。 1. SELECT:用于从一个或多个表中检索数据。可以指定要检索的列、过滤条件和排序方式等。 2. SHOW:用于查看数据库或表的信息。有多种SHOW命令,如SHOW DATABASES用于查看数据库列表,SHOW TABLES用于查看某个数据库中的表列表,SHOW COLUMNS FROM table_name用于查看表的列信息等。 3. DESCRIBE:用于查看表结构的详细信息。可以通过DESCRIBE或EXPLAIN加上表名来查看表中各个列的属性、类型、索引等信息。 4. EXPLAIN:用于查看查询语句的执行计划,并分析查询性能。可以通过EXPLAIN加上SELECT语句来查看该查询语句的执行过程,包括如何访问表、连接方式、索引使用情况等。 除了以上常用的查询命令,MySQL还提供了许多其他的查询语句命令和子句,如INSERT INTO、UPDATE、DELETE、GROUP BY、HAVING、ORDER BY等,用于实现更复杂的查询操作。 总之,MySQL数据库查询语句命令是用于检索和展示数据库中存储的数据和表结构的,通过这些命令可以灵活地操作和管理数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值