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的后台杀死这个进程,从而释放出宝贵的连接资源


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM