【mysql】排错和调优

通用的一些排错方法。

1、查看进程信息

sql 复制代码
mysql> show full processlist;

mysql> show processlist;

2、information_schema

information_schema这张数据表保存了MySQL服务器所有数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权限等。再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面。

常用下面三张表来查原因:

  • innodb_trx 当前运行的所有事务
  • innodb_locks 当前出现的锁
  • innodb_lock_waits 锁等待的对应关系

2.1 示例1,查找死锁的事务

sql 复制代码
mysql> select * from information_schema.innodb_trx;

图中红色语句++LOCK WAIT ++为占用系统资源的语句,当一只在等待时,此时直接杀掉这个锁会时最好的选择,执行" kill trx_mysql_thread_id "。从图中可以看出 trx_mysql_thread_id738178711 , 所以我们执行:" kill 738178711 "即可。

2.2 示例2,查找用时比较久的进程

sql 复制代码
mysql> SELECT * from information_schema.`PROCESSLIST` WHERE Time > 1000 ORDER BY TIME desc;

查询运行时间超过1000秒的进程,结果类似:

相关推荐
金仓数据库几秒前
性能提升超十倍!金仓时序数据库首入北京轨交TCC
数据库·时序数据库
java1234_小锋1 分钟前
Redis 如何实现持久化?RDB 和 AOF 的区别是什么?如何选择合适的持久化方式?
数据库·redis·bootstrap
倔强的石头10611 分钟前
深度解析:数据库内核如何通过逻辑推理与常值推导突破去重性能瓶颈
数据库·oracle
为什么不问问神奇的海螺呢丶20 分钟前
Oracle database SYSAUX 表空间占用率过高处理方案
数据库·oracle
fengxin_rou21 分钟前
【MySQL SQL 执行全链路剖析】:执行计划、慢查询与经典场景优化指南
数据库·sql·mysql
betazhou23 分钟前
LOG_ARCHIVE_DEST_2 ORA-01033: ORACLE initialization or shut
数据库·oracle·oracle19c adg
思诺学长26 分钟前
MySQL——数据库并发控制策略: 乐观锁与悲观锁
数据库
fengxin_rou26 分钟前
【Spring AI 集成 DeepSeek 实现 AI 摘要与 RAG 问答】:从原理到落地实践
数据库·mysql·rag·deepseek
No8g攻城狮29 分钟前
【异常解决】SpringBoot3 + 人大金仓 V8+MyBatis-Plus 获取新增自增 ID
数据库·mybatis·人大金仓·国产信创
鱼听禅30 分钟前
CentOS搭建SVN服务器
数据库·postgresql·sqlserver