(1)查出活动连接列表及其进程ID
select*frompg_stat_activity;
(2)取消连接上的活动查询
selectpg_cancel_backend(procid);
该操作不会终止连接本身
(3)终止该连接
selectpg_terminate_backend(procid);
如果你未停止某个连接上正在执行的语句就直接终止该连接,那么这些语句此时也会被停止掉。在上述步骤2执行完毕后,客户端应用的挂起状态被解除,即客户端可以重新执行语句,有些着急的用户会在此时再次执行刚刚被终止掉的语句,这又会导致系统陷入之前的状态。为了避免此种情况的发生,可以采用直接
终止连接的方式。
如果你希望一次性终止某个用户的所有连接,那么在9.2版及之后的版本上可以执行以下语句:
selectpg_terminate_backend(pid)frompg_stat_activitywhereusername='some_role';
在9.2版之前的版本上可以执行以下语句:
selectpg_terminate_backend(procpid)frompg_stat_activitywhereusername='some_role';
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。