当前位置:首页 > 数据库 > 正文

如何查询MySQL数据库连接

使用命令行执行 mysql -u 用户名 -p密码 -h 主机地址 -P 端口 数据库名,回车后根据提示输入密码(若 -p 后未直接跟密码),成功连接后终端将显示 mysql> 提示符。

什么是MySQL连接数据库?

MySQL连接数据库指应用程序与MySQL服务器建立的通信通道,当用户访问网站、APP或后台系统时,程序会通过连接与数据库交互数据,查询连接状态可监控资源使用、排查性能问题或检测异常访问。


通过SQL命令直接查询(推荐)

方法1:SHOW PROCESSLIST

在MySQL客户端执行:

SHOW FULL PROCESSLIST;
  • 结果说明
    • Id:连接ID
    • User:连接用户
    • Host:客户端IP和端口
    • db:访问的数据库名
    • Command:执行命令类型(如Query/Sleep)
    • Time:连接持续时间(秒)
    • State:当前状态
    • Info:执行的SQL语句

方法2:查询information_schema系统表

SELECT * FROM information_schema.PROCESSLIST;

优势:可筛选特定条件(如过滤休眠连接):

如何查询MySQL数据库连接  第1张

SELECT * FROM information_schema.PROCESSLIST 
WHERE COMMAND != 'Sleep' AND TIME > 10;

通过命令行工具查询

方法1:mysqladmin命令

mysqladmin -u用户名 -p密码 processlist

示例输出:

+----+------+-----------+----+---------+------+-------+------------------+
| Id | User | Host      | db | Command | Time | State | Info             |
+----+------+-----------+----+---------+------+-------+------------------+
| 5  | root | localhost | db | Query   | 0    | init  | SHOW PROCESSLIST |
+----+------+-----------+----+---------+------+-------+------------------+

方法2:结合系统命令

查看MySQL端口(默认3306)的连接:

netstat -an | grep :3306

使用图形化管理工具

工具1:phpMyAdmin

  1. 登录后进入首页
  2. 点击顶部菜单 状态进程列表
  3. 实时显示所有连接及执行的SQL

工具2:MySQL Workbench

  1. 连接数据库后,左侧导航栏点击 Management
  2. 选择 Client Connections
  3. 查看连接数、用户来源和活动状态

通过编程语言查询(示例)

Python示例

import pymysql
# 建立管理连接
conn = pymysql.connect(
    host='localhost',
    user='admin',
    password='secure_pass',
    database='information_schema'
)
cursor = conn.cursor()
cursor.execute("SHOW PROCESSLIST")
for row in cursor.fetchall():
    print(f"ID:{row[0]} User:{row[1]} SQL:{row[7]}")
cursor.close()
conn.close()

PHP示例

<?php
$conn = new mysqli("localhost", "admin", "secure_pass", "information_schema");
$result = $conn->query("SHOW FULL PROCESSLIST");
while ($row = $result->fetch_assoc()) {
    echo "ID: " . $row['Id'] . " | SQL: " . $row['Info'] . "<br>";
}
$conn->close();
?>

注意事项与最佳实践

  1. 权限控制

    • 仅允许管理员账号执行连接查询(普通账号无PROCESS权限)
    • 授权命令:GRANT PROCESS ON *.* TO 'user'@'host';
  2. 性能影响

    • 避免高频查询(SHOW PROCESSLIST会短暂锁表)
    • 生产环境建议使用information_schema(非阻塞查询)
  3. 安全防护

    • 监控异常IP的长时间连接(如TIME>300
    • 及时终止反面连接:KILL [连接ID];
  4. 连接数优化

    • 检查max_connections配置:SHOW VARIABLES LIKE 'max_connections';
    • 建议设置:max_connections = 实际需求 + 20%冗余

常见问题解决

Q1:查询结果为空或权限不足

  • 检查账号是否有PROCESS权限
  • 使用sudo运行命令(Linux系统)

Q2:连接数突然暴增

  1. 紧急终止所有非关键连接:
    SELECT CONCAT('KILL ', id, ';') 
    FROM information_schema.PROCESSLIST 
    WHERE USER = '可疑用户' 
    INTO OUTFILE '/tmp/kill.sql';
    SOURCE /tmp/kill.sql;
  2. 检查程序是否未释放连接(如PHP未关闭mysqli

Q3:大量Sleep连接占用资源

  • 修改wait_timeout(默认8小时):
    SET GLOBAL wait_timeout = 300;  -- 5分钟无活动断开

引用说明
本文方法基于MySQL 8.0官方文档,参考来源:

  • MySQL SHOW PROCESSLIST Documentation
  • information_schema.PROCESSLIST Table
    操作建议遵循OWASP数据库安全指南。
0