在 Linux 系统中,查看数据库连接状态是运维与开发人员日常工作中常见的任务,不同数据库管理系统(DBMS)有不同的工具和方法,本文将详细介绍 MySQL、PostgreSQL、Oracle 和 SQLite 的连接查询方式,帮助读者高效获取连接信息。

MySQL 数据库连接查询
MySQL 提供了多种命令行工具来查看连接,最常用的是 mysqladmin 和 SQL 语句结合的方式。
使用 mysqladmin 工具
mysqladmin 是 MySQL 自带的客户端管理工具,通过 -i 参数可定期刷新连接状态。
mysqladmin -u root -p -i 2 status
执行后每 2 秒更新一次服务器状态,输出包含当前连接数(Threads)、运行时间等信息,若需详细连接列表,可使用:
mysqladmin -u root -p processlist
该命令会列出所有活跃连接的线程 ID、用户、主机、数据库及当前操作。
通过 SQL 语句查询
登录 MySQL 后,执行以下 SQL 可获取更详细的连接信息:
SHOW PROCESSLIST;
或使用系统表 information_schema.processlist:
SELECT * FROM information_schema.processlist WHERE db IS NOT NULL;
此方法能过滤掉未指定数据库的连接,结果包含线程 ID、用户、主机、数据库、命令类型等字段。

PostgreSQL 数据库连接查询
PostgreSQL 的连接信息可通过内置命令 pg_stat_activity 视图获取,需具备相应权限。
使用 psql 命令行工具
登录 PostgreSQL 后,执行:
SELECT pid, usename, datname, client_addr, query_start, state FROM pg_stat_activity;
pid:进程 ID,可用于终止异常连接;usename:连接用户;datname:数据库名称;client_addr:客户端 IP 地址;query_start:查询开始时间;state:连接状态(如 idle、active)。
若需按时间排序查看长连接,可添加 ORDER BY query_start DESC。
终止特定连接
若发现异常连接,可通过进程 ID 终止:
SELECT pg_terminate_backend(pid);
Oracle 数据库连接查询
Oracle 的连接信息可通过 v$session 动态视图查询,需以管理员身份登录。
查询活跃连接
使用 SQL*Plus 或其他 Oracle 客户端执行:
SELECT sid, serial#, username, machine, program, logon_time FROM v$session WHERE username IS NOT NULL;
sid/serial#:会话标识,用于终止连接;username:连接用户;machine:客户端主机名;program:客户端程序名称;logon_time:登录时间。
终止连接
若需终止某个会话,执行:

ALTER SYSTEM KILL SESSION 'sid,serial#';
SQLite 数据库连接查询
SQLite 作为轻量级嵌入式数据库,通常单文件部署,连接数较少,可通过 .database 命令查看当前连接的数据库文件:
sqlite3 test.db sqlite> .database
输出格式为 seq|name|file,显示数据库文件的序列号、别名及路径,由于 SQLite 默认单连接,一般无需额外查询连接状态。
通用技巧:使用系统监控工具
除数据库自带工具外,Linux 系统的 netstat 或 ss 命令也可辅助排查网络层面的数据库连接:
netstat -tulpn | grep mysql # 查看 MySQL 监听端口 ss -tulpn | grep 5432 # 查看 PostgreSQL 监听端口
这些命令能快速定位数据库服务的网络连接情况,适合初步故障排查。
FAQs 相关问答
Q1:为什么用 SHOW PROCESSLIST 查不到任何连接?
A:可能原因包括:
- 未使用具有足够权限的用户登录(如普通用户无法查看其他用户的连接);
- 数据库配置了连接限制(如
max_connections过低),导致无可用连接; - 连接已断开但进程未及时清理,可尝试重启 MySQL 服务释放资源。
Q2:如何区分正常连接和异常连接?
A:可通过以下特征判断:
- 时长:长时间运行的查询(如
query_start超过 1 小时)可能是死锁或慢查询; - 状态:
state为idle但占用连接数的连接,可考虑释放; - 来源:陌生 IP 或异常程序的连接(如非业务应用发起的连接)需重点排查。
建议结合业务场景设置连接超时时间(如 MySQL 的wait_timeout),自动终止空闲连接。
【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!
发表回复