在使用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 = 10net.ipv4.tcp_keepalive_time = 30net.ipv4.tcp_window_scaling = 0net.ipv4.tcp_sack = 0
綜上得出結論,Apache-XMLRpc用戶端存在串連不關閉的情況,當然前提是使用XmlRpcCommonsTransportFactory(使用httpclient實現的HTTP協議),Apache-XMLRpc除此之外,還有通過Socket實現一個LiteHttp,經過測試XmlRpcLite14HttpTransportFactory建立的串連沒有問題,不會出現串連不關閉的情況,抓包如下:
修改如下:
XmlRpcClient instance = new XmlRpcClient();instance.setTransportFactory(new XmlRpcLite14HttpTransportFactory(instance));