POSTGRESQL 查看用户使用情况以及杀掉相应的进程

一、查看哪些用户在链接数据库

select * from pg_stat_activity ;

  这里的pg_stat_activity其实是一个视图,它的定义可以在postgres这个数据库里面的视图部分找到。

 
二、杀死进程
  现在我们找出所有连接到数据库的进程了,那么如何去杀死那些IDEL的进程从而释放出连接呢?如果pg的版本是 8.4及以上的,可以很简单地用下面的语句来杀死所有IDEL进程 :
SELECT pg_terminate_backend(procpid) FROM pg_stat_activity WHERE current_query=<IDLE>
  pg_terminate_backend是pg的内部方法,另外还有一个叫pg_cancel_backend,这个方法在8.4以前的版本中就一直存在。这两个方法的区别在于:
  • pg_cancel_backend    只是取消当前某一个进程的查询操作,但不能释放数据库连接
  • pg_terminate_backend    可以在pg的后台杀死这个进程,从而释放出宝贵的连接资源

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。