1,如果一端的Socket被關閉(或主動關閉,或因為異常退出而 引起的關閉),另一端仍發送數據,發送的第一個數據包引發該異常(Connect reset by peer)。
Socket默認連接60秒,60秒之內沒有進行心跳交互,即讀寫數據,就會自動關閉連接。
2,一端退出,但退出時並未關閉該連接,另一端如果在從連接中讀數據則拋出該異常(Connection reset)。
簡單的說就是在連接斷開后的讀和寫操作引起的。
Connection reset by peer的常見原因:
1)服務器的並發連接數超過了其承載量,服務器會將其中一些連接關閉;(可參考提高服務器並發tcp連接數)
如果知道實際連接服務器的並發客戶數沒有超過服務器的承載量,則有可能是中了病毒或者木馬,引起網絡流量異常。可以使用netstat -an查看網絡連接情況。
2)客戶關掉了瀏覽器,而服務器還在給客戶端發送數據;
3)瀏覽器端按了Stop;
這兩種情況一般不會影響服務器。但是如果對異常信息沒有特別處理,有可能在服務器的日志文件中,重復出現該異常,造成服務器日志文件過大,影響服務器的運行。可以對引起異常的部分,使用try…catch捕獲該異常,然后不輸出或者只輸出一句提示信息,避免使用e.printStackTrace();輸出全部異常信息。
4)防火牆的問題;
如果網絡連接通過防火牆,而防火牆一般都會有超時的機制,在網絡連接長時間不傳輸數據時,會關閉這個TCP的會話,關閉后在讀寫,就會導致異常。 如果關閉防火牆,解決了問題,需要重新配置防火牆,或者自己編寫程序實現TCP的長連接。實現TCP的長連接,需要自己定義心跳協議,每隔一段時間,發送一次心跳協議,雙方維持連接。