Linux环境下如何查看正在连接的数据库?

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

Linux环境下如何查看正在连接的数据库?

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、用户、主机、数据库、命令类型等字段。

Linux环境下如何查看正在连接的数据库?

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:登录时间。

终止连接

若需终止某个会话,执行:

Linux环境下如何查看正在连接的数据库?

ALTER SYSTEM KILL SESSION 'sid,serial#';

SQLite 数据库连接查询

SQLite 作为轻量级嵌入式数据库,通常单文件部署,连接数较少,可通过 .database 命令查看当前连接的数据库文件:

sqlite3 test.db
sqlite> .database

输出格式为 seq|name|file,显示数据库文件的序列号、别名及路径,由于 SQLite 默认单连接,一般无需额外查询连接状态。

通用技巧:使用系统监控工具

除数据库自带工具外,Linux 系统的 netstatss 命令也可辅助排查网络层面的数据库连接:

netstat -tulpn | grep mysql  # 查看 MySQL 监听端口
ss -tulpn | grep 5432        # 查看 PostgreSQL 监听端口

这些命令能快速定位数据库服务的网络连接情况,适合初步故障排查。

FAQs 相关问答

Q1:为什么用 SHOW PROCESSLIST 查不到任何连接?
A:可能原因包括:

  • 未使用具有足够权限的用户登录(如普通用户无法查看其他用户的连接);
  • 数据库配置了连接限制(如 max_connections 过低),导致无可用连接;
  • 连接已断开但进程未及时清理,可尝试重启 MySQL 服务释放资源。

Q2:如何区分正常连接和异常连接?
A:可通过以下特征判断:

  • 时长:长时间运行的查询(如 query_start 超过 1 小时)可能是死锁或慢查询;
  • 状态stateidle 但占用连接数的连接,可考虑释放;
  • 来源:陌生 IP 或异常程序的连接(如非业务应用发起的连接)需重点排查。
    建议结合业务场景设置连接超时时间(如 MySQL 的 wait_timeout),自动终止空闲连接。

【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!

(0)
热舞的头像热舞
上一篇 2025-10-22 01:18
下一篇 2025-10-22 01:21

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

广告合作

QQ:14239236

在线咨询: QQ交谈

邮件:asy@cxas.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信