当前位置: 首页 > 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 连接,提升数据库的稳定性和性能!🎯

相关文章:

  • 【Linux】华为服务器使用U盘安装统信操作系统
  • C语言实现单链表
  • Unity基础——资源导入
  • Ubuntu 24.04 登录禁用用户列表
  • mapbox添加自定义图片绑定点击事件,弹窗为自定义组件
  • Mock测试:移动端分辨率适配
  • 【deepseek之我问】如何把AI技术与教育相结合,适龄教育,九年义务教育,以及大学教育,更着重英语学习。如何结合,给出观点。结合最新智能体Deepseek
  • MySQL企业开发中高频使用语句
  • nginx 正向代理与反向代理
  • 【Linux网络编程】高效I/O--select/poll服务器
  • 4.1 Go结构体的指针
  • 上海商米科技通信工程师后端开发岗内推
  • 基于SpringBoot的图书进销存管理系统开发与设计
  • 【AHK】资源管理器自动化办公实例/自动连点设置
  • go-zero中定时任务的用法
  • 如何搭建和管理 FTP 服务器
  • 取topN不同算法的实现的性能差别
  • Java线程池入门04
  • Neo4j 图数据库安装与操作指南(以mac为例)
  • SpringBatch简单处理多表批量动态更新
  • 菏泽网站建设招聘/seo搜索引擎专员
  • 遵义会议在线/西安seo外包公司
  • 如何做话费卡回收网站/高端seo服务
  • 哈尔滨市建设网/深圳优化公司哪家好
  • 手机自己做网站吗/精准客源app
  • 网站上的文章做参考文献/万能软文范例800字