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的后台杀死这个进程,从而释放出宝贵的连接资源
posted @ 2014-11-14 12:14  李秋  阅读(14457)  评论(0编辑  收藏  举报