现在的位置: 首页 > 综合 > 正文

Apache-XMLRpc客户端连接不关闭问题解决

2013年09月15日 ⁄ 综合 ⁄ 共 926字 ⁄ 字号 评论关闭

          在使用Apache XML-RPC客户端时,采用默认的XmlRpcCommonsTransportFactory创建连接时,会出现客户端已经做完请求操作,但是系统中的该连接资源没释放。通过两点可以明显观察到现象:

          1. 在系统中通过netstat -anop|grep 9843|grep ESTABLISHED,发现有一些连接仍然建立着;

          2. 通过使用tcpdump对9843端口进行抓包,抓包截图如下:

           发现建立连接[SYN],[SYN, ACK],[ACK]完成了TCP连接的三次握手,中间通过PSH进行消息负荷的传送,但是在最后,客户端没有在TCP通道上传输任何数据,等待了20秒后,有服务端主动关闭了连接。

           正常的TCP建立连接和关闭连接的流程如下图所示,建立连接时三次握手,关闭连接是需要四次握手,而当前情况只有服务端向客户端发送的单向FIN消息,而且该消息与上一条消息间隔了20秒,可见Linux系统的TCP空闲超时时间是20秒。

      

        可以通过修改/etc/sysctl.conf文件来限制,运行/sbin/sysctl -p命令使其生效。

net.ipv4.tcp_fin_timeout = 10
net.ipv4.tcp_keepalive_time = 30
net.ipv4.tcp_window_scaling = 0
net.ipv4.tcp_sack = 0

    综上得出结论,Apache-XMLRpc客户端存在连接不关闭的情况,当然前提是使用XmlRpcCommonsTransportFactory(使用httpclient实现的HTTP协议),Apache-XMLRpc除此之外,还有通过Socket实现一个LiteHttp,经过测试XmlRpcLite14HttpTransportFactory创建的连接没有问题,不会出现连接不关闭的情况,抓包如下:


    修改如下:
XmlRpcClient instance = new XmlRpcClient();
instance.setTransportFactory(new XmlRpcLite14HttpTransportFactory(instance));




抱歉!评论已关闭.