版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/youzi_yun/article/details/82917797
- 查看数据库正在执行的进程
select * from pg_stat_activity
每个服务器进程的pg_stat_activity视图将有一行,显示与该进程的当前活动相关的信息。
- 杀死进程
现在我们找出所有连接到数据库的进程了,那么如何去杀死那些IDEL的进程从而释放出连接呢?如果pg的版本是 8.4及以上的,可以很简单地用下面的语句来杀死所有IDEL进程 :
SELECT pg_terminate_backend(procpid)
pg_cancel_backend 只是取消当前某一个进程的查询操作,但不能释放数据库连接
pg_terminate_backend 可以在pg的后台杀死这个进程,从而释放出宝贵的连接资源
- 进程参数详解
Column | Type | 描述 |
---|---|---|
datid | oid | 该后端连接到的数据库的OID |
datname | name | 该后端连接到的数据库的名称 |
pid | integer | 此后端的进程ID |
usesysid | oid | 登录到此后端的用户的OID |
usename | name | 登录到此后端的用户的名称 |
application_name | text | 连接到此后端的应用程序的名称 |
client_addr | inet | |
client_hostname | text | 已连接客户端的主机名,由client_addr的反向DNS查找报告。只有当 启用log_hostname时,该字段对于IP连接才是非空的。 |
client_port | integer | 客户端用于与此后端进行通信的TCP端口号,如果使用Unix套接字,则为-1 |
backend_start | timestamp | 此过程开始的时间,即客户端连接到服务器的时间 |
xact_start | timestamp | 此进程当前事务已启动的时间;如果没有事务处于活动状态,则为null。如果当前查询是其第一个事务,则此列等于query_start列。 |
query_start | timestamp | 当前活动查询开始的时间,或者状态未 处于活动状态,最后一个查询开始时的时间 |
state_change | timestamp | 时值状态 上次更改 |
waiting | boolean | 如果此后端当前正在等待锁定,则为真 |
query | text | 此后端的最新查询的文本。如果 state 处于活动状态,则此字段显示当前正在执行的查询 在所有其他状态下,它显示最后执行的查询。 |
state | text | 当前这个后端的整体状态。可能的值是:active:后端正在执行查询。idle:后端正在等待新的客户端命令。idle in transaction:闲置在事务中,后端处于事务中,但当前未执行查询。idle in transaction (aborted):与idle in transaction类似 ,除了事务中的某个语句导致错误。fastpath function call:快速路径函数调用,后端正在执行快速路径函数。 |