当前位置: 首页 > news >正文

information_schema.processlist 表详解

information_schema.processlist 表(或 SHOW PROCESSLIST; 命令)用于查看 MySQL 当前所有的连接进程,帮助管理员监控数据库活动并排查性能问题。以下是该表的字段及其具体含义:


🔹 information_schema.processlist 字段详解

字段名数据类型含义示例
IDBIGINT连接的唯一 ID(线程 ID)12345
USERVARCHAR连接的 MySQL 用户root
HOSTVARCHAR连接的客户端主机和端口192.168.1.100:53421
DBVARCHAR连接使用的数据库(为空表示未选择数据库)test_db
COMMANDVARCHAR当前连接的执行状态Query / Sleep / Binlog Dump
TIMEINT该状态已持续的时间(秒)120
STATEVARCHAR当前执行 SQL 的具体状态Sending data
INFOLONGTEXT连接执行的 SQL 语句(可能为 NULLSELECT * FROM users;

🔹 关键字段解析

1️⃣ ID(连接 ID)
  • 连接的唯一标识,可以用于终止特定连接:
    KILL 12345;
    
2️⃣ USER(连接的 MySQL 用户)
  • 连接数据库的用户名。
  • root 表示管理员用户,其他可能是业务用户。
  • 可以用来筛选特定用户的连接
    SELECT * FROM information_schema.processlist WHERE USER = 'app_user';
    
3️⃣ HOST(客户端主机地址和端口)
  • 显示连接 MySQL 服务器的客户端 IP 和端口号,例如:
    192.168.1.100:53421
    
  • 可以用来检查哪些 IP 连接较多
    SELECT HOST, COUNT(*) AS conn_count 
    FROM information_schema.processlist 
    GROUP BY HOST 
    ORDER BY conn_count DESC;
    
4️⃣ DB(使用的数据库)
  • 连接当前选中的数据库,NULL 表示未选择数据库。
5️⃣ COMMAND(连接执行的操作)
  • 代表当前连接的执行状态,常见取值:

    COMMAND说明
    Sleep连接空闲(等待新查询)
    Query正在执行 SQL 语句
    Connect正在建立连接
    Binlog Dump复制(主从同步)
    DaemonMySQL 后台线程
  • 找出所有空闲连接(可以适当关闭):

    SELECT * FROM information_schema.processlist WHERE COMMAND = 'Sleep';
    
6️⃣ TIME(状态持续时间)
  • 该状态已持续的时间(秒)。
  • 如果 COMMAND='Sleep'TIME 很长,可能说明有长时间空闲的连接未释放
  • 找出空闲时间超过 1 小时的连接
    SELECT * FROM information_schema.processlist WHERE COMMAND = 'Sleep' AND TIME > 3600;
    
7️⃣ STATE(SQL 具体状态)
  • 代表 SQL 语句的执行状态,便于分析慢查询:

    STATE说明
    NULL没有运行中的 SQL
    Checking table正在检查表
    Sending data正在返回结果集
    Locked事务锁等待中
    Copying to tmp table正在创建临时表(可能影响性能)
    Sorting result正在执行排序
    Waiting for table lock等待表锁(可能导致阻塞)
  • 找出所有正在等待锁的查询

    SELECT * FROM information_schema.processlist WHERE STATE LIKE '%lock%';
    
8️⃣ INFO(正在执行的 SQL 语句)
  • 显示当前连接正在执行的 SQL 语句(可能为空)。
  • 如果 SHOW PROCESSLIST; 只显示部分 SQL,可以用 SHOW FULL PROCESSLIST; 查看完整 SQL

🔹 实用 SQL 监控示例

✅ 查询当前连接数
SELECT COUNT(*) FROM information_schema.processlist;
✅ 查询每个用户的连接数
SELECT USER, COUNT(*) AS conn_count 
FROM information_schema.processlist 
GROUP BY USER 
ORDER BY conn_count DESC;
✅ 查询当前执行 SQL 语句最多的 IP
SELECT HOST, COUNT(*) AS conn_count 
FROM information_schema.processlist 
WHERE COMMAND != 'Sleep' 
GROUP BY HOST 
ORDER BY conn_count DESC;
✅ 查询执行时间超过 10 秒的 SQL
SELECT * FROM information_schema.processlist WHERE COMMAND='Query' AND TIME > 10;
✅ 查询所有正在执行的 SQL
SELECT ID, USER, HOST, DB, TIME, STATE, INFO 
FROM information_schema.processlist 
WHERE COMMAND='Query';
✅ 终止某个慢查询
KILL 12345;

🔹 结论

  • information_schema.processlist 提供所有连接的详细信息,是 MySQL 监控的重要工具。
  • 结合 COMMANDSTATETIMEINFO 字段,可以分析慢查询、找出死锁、清理空闲连接,优化数据库性能。

🚀 建议

  • 结合 SHOW FULL PROCESSLIST; 获取完整 SQL 语句。
  • 监控 Sleep 连接数,避免过多空闲连接浪费资源。
  • 关注 LockedWaiting for table lock 等状态,检查是否有事务阻塞

这样可以更好地管理 MySQL 连接,提升数据库的稳定性和性能!🎯

http://www.lryc.cn/news/544383.html

相关文章:

  • P8623 [蓝桥杯 2015 省 B] 移动距离
  • 2025年Linux主力系统选择指南:基于最新生态的深度解析(附2025年发行版对比速查表)
  • [密码学实战]Java实现国密(SM2)密钥协商详解:原理、代码与实践
  • 015--基于STM32F103ZET6的智能风扇设计
  • 基于YOLO11深度学习的遥感视角农田检测与分割系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分割、人工智能
  • RBF神经网络+NSGAII多目标优化算法,工艺参数优化、工程设计优化(Matlab)
  • Zookeeper(79)如何进行Zookeeper的监控?
  • 运动想象 (MI) 分类学习系列 (17) : CCSM-FT
  • start DL from stratch (2)!!!
  • 【深入浅出:Core-JS Legacy 的降级兼容指南】
  • 通义灵码插件安装入门教学 - IDEA(安装篇)
  • STM32之时钟树
  • Unity插件-Mirror使用方法(一)Mirror介绍
  • HVAC 设计:使用 Ansys Discovery 探索更好的设计
  • ChatGPT 提示词框架
  • 004-利用Docker安装Mysql
  • Dify使用和入门
  • 高效管理 React 状态和交互:我的自定义 Hooks 实践
  • ESP 32控制无刷电机2
  • 揭开人工智能中 Tokens 的神秘面纱
  • 萌新学 Python 之 random 函数
  • 2-2linux系统IO
  • 周边游平台设计与实现(代码+数据库+LW)
  • 视频批量分段工具
  • Android -- 使用Sharepreference保存List储存失败,原因是包含Bitmap,drawable等类型数据
  • java项目之基于ssm的图书馆书库管理系统(源码+文档)
  • 编写一个程序,输入一个数字并输出其阶乘(Python版)
  • dify基础之prompts
  • 实践教程:使用DeepSeek实现PDF转Word的高效方案
  • 网络安全审计员