遇到异常连接时,需要将对应连接杀掉,可能是连接占用了过多CPU或是IO,影响了业务,或是时间过长的空闲事务.

pg对于杀掉连接提供了专门的命令,一般情况下使用pg_cancel_backend就可以,不过操作取消不掉,可以使用pg_terminate_backend,如果pg_terminate_backend命令,仍然无法将连接杀掉,此时可以使用tcpkill,将连接的网络通信连接直接杀掉。

有时候,出现使用pg_terminate_backend也杀不掉的连接,通常是网络的问题,诸如misrouted packets,retransmissions,blocked sockets,timeouts,stalls此类的网络问题,都在等待客户端和pg通信的中断。

有时候网络的socket会处于这种状态:当pg做写操作时,被中断了。

在这种状态中,pg等待着来自客户端的回复,来确认客户端已收到数据,或是经由操作系统将该网络连接标记为损坏的,中断的。如果这些没有发生,那么pg就会一直等待直到收到客户端中断的命令。

此时可以使用tcpkill中断网络连接,然后操作系统就会关闭network socket,这样pg的连接也就自动退出了。

命令如下:

tcpkill -i eth0 -9 port client_port

-i: 指定数据库使用的是哪个network interface

client_port: 连接数据库连接的客户端端口

执行后,输出下面的信息后,可确认执行完成:

[root@pg2 ~]# tcpkill -i eth0 -9 port 60988
tcpkill: listening on eth0 [port 60988]
172.16.3.94:60988 > 172.16.3.95:1921: R 1241262920:1241262920(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241263157:1241263157(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241263631:1241263631(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241264342:1241264342(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241265290:1241265290(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241266475:1241266475(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241267897:1241267897(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241269556:1241269556(0) win 0
172.16.3.94:60988 > 172.16.3.95:1921: R 1241271452:1241271452(0) win 0
172.16.3.95:1921 > 172.16.3.94:60988: R 4254183996:4254183996(0) win 0
172.16.3.95:1921 > 172.16.3.94:60988: R 4254184253:4254184253(0) win 0
172.16.3.95:1921 > 172.16.3.94:60988: R 4254184767:4254184767(0) win 0
172.16.3.95:1921 > 172.16.3.94:60988: R 4254185538:4254185538(0) win 0
172.16.3.95:1921 > 172.16.3.94:60988: R 4254186566:4254186566(0) win 0
172.16.3.95:1921 > 172.16.3.94:60988: R 4254187851:4254187851(0) win 0

这个命令执行完成,有时可能需要几分钟,所以要耐心等待一下。

tcpkill命令是网络嗅探工具包dsniff中的一个工具,如果要使用tcpkill,要先安装好dsniff。

使用源码安装不太容易,常报错,推荐使用yum安装,这里使用的是阿里云的yum源。

这个文件的安装走的是epel.repo部分。

 wget -O CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
yum clean all
yum makecache

pg数据库杀掉连接的更多相关文章

  1. JPA连接PG数据库时间类型查询报错的修改

    PG数据库中的时间格式规范: https://blog.csdn.net/sky_limitless/article/details/79527665 to_data 转换为 普通的时间格式 to_t ...

  2. oracle杀掉连接

    相关sql --查看当前连接 select count(*) from v$process --数据库允许的最大连接数 select value from v$parameter where name ...

  3. T-SQL 关闭数据库所有连接

    原文引用自: http://www.cnblogs.com/kissazi2/p/3462202.html 下面给出一种删除数据库活动连接的方式.将下面代码段中的"--修改一下"处 ...

  4. php判断数据库是否连接成功的测试例子

    php判断数据库是否连接成功的测试例子 如果出现数据库配置不正确的错误,请看php与mysql的配置教程: win7系统下如何配置php-Apache-mysql环境 http://www.cnblo ...

  5. java中与数据库的连接

    package unitl01; import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet; ...

  6. jsp与数据库的连接

    经过一段时间的学习与上网查资料,我已经成功的用java语言连接上了数据库, 本以为同理jsp跟数据库的连接肯定水到渠成的,但是在经过尝试很多次后我发现现实永远是骨感的,最终结果是花了一个下午的时间去建 ...

  7. 数据库最大连接池max pool size

    本文导读:Max Pool Size如果未设置则默认为100,理论最大值为32767.最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影 ...

  8. jsp_数据库的连接

    一.添加数据库以及表 在这里我们使用的是mysql数据库 二.配置数据库的驱动程序 将mysql的驱动程序复制到Tomcat目录下的lib目录中 注:在Tomcat中如果配置了新的jar包,则配置完成 ...

  9. [转]Hibernate不能自动建表解决办法及Hibernate不同数据库的连接及SQL方言

    最近开始学Hibernate,看的是李刚的那本<轻量级java ee企业应用实战>.头一个hibernate程序,我原原本本的按照书上例子写下来,同时只是改动了些mysql的连接参数,并且 ...

随机推荐

  1. DDMS_Threads的简单使用

    title: DDMS_Threads的简单使用 date: 2016-07-20 00:44:35 tags: [DDMS] categories: [Tool,IDE] --- 概述 本文记录在 ...

  2. 第十次PSP

  3. Notes of Daily Scrum Meeting(11.5)

    Notes of Daily Scrum Meeting(11.5) 今天是我们学习学长代码,同时学习安卓语言的第三天.我们和学长沟通了一下,仔细讨论后得出一个结论,学长在 IOS平台上的代码可以借鉴 ...

  4. linux 常用命令-编辑模式

    1.编辑模式就是通过vi或者vim打包文件,进入编辑模式,vim是vi的升级版,vim除了报错vi的命令外还包括一些额外的命令,本文以vim命令为例,如果需要查询而不需要编辑文件则可以通过cat命令查 ...

  5. 【转】python 三种遍历list的方法

    [转]python 三种遍历list的方法 #!/usr/bin/env python # -*- coding: utf-8 -*- if __name__ == '__main__': list ...

  6. 【图论】POJ-3169 差分约束系统

    一.题目 Description Like everyone else, cows like to stand close to their friends when queuing for feed ...

  7. Java集合技巧

    集合的一些技巧:   需要唯一吗? 需要:Set 需要制定顺序:  需要: TreeSet 不需要:HashSet 但是想要一个和存储一致的顺序(有序):LinkedHashSet 不需要:List ...

  8. 构建基于Chromium的应用程序(Winform程序加载Html页面)

    chromium是google chrome浏览器所采用的内核,最开始由苹果的webkit发展而出,由于webkit在发展上存在分歧,而google希望在开发上有更大的自由度,2013年google决 ...

  9. Intellij IDEA中file size exceeds configured limit解决

    把Hadoop源码导入IDEA中后,其中有个ClientNamenodeProtocolProtos文件代码高达82997行,IDEA直接就不把它当java类看了,报file size exceeds ...

  10. sqlsever实现更改字段名

    新建表:create table [表名]([自动编号字段] int IDENTITY (1,1) PRIMARY KEY ,[字段1] nVarChar(50) default '默认值' null ...