自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

java.net.SocketException四大異常解決方案

開發(fā) 后端
java.net.SocketException在我們使用的時候會出現(xiàn)很多異常,這些會影響到我們的學習和使用。下面我們就仔細的研究一下。

java.net.SocketException如何才能更好的使用呢?這個就需要我們先要了解有關(guān)這個語言的相關(guān)問題。希望大家有所幫助。那么我們就來看看有關(guān)java.net.SocketException的相關(guān)知識。

第1個異常是 java.net.BindException:Address already in use: JVM_Bind。

該異常發(fā)生在服務器端進行new ServerSocket(port)(port是一個0,65536的整型值)操作時。異常的原因是以為與port一樣的一個端口已經(jīng)被啟動,并進行監(jiān)聽。此時用netstat –an命令,可以看到一個Listending狀態(tài)的端口。只需要找一個沒有被占用的端口就能解決這個問題。#t#

第2個異常是java.net.SocketException: Connection refused: connect。

該異常發(fā)生在客戶端進行 new Socket(ip, port)操作時,該異常發(fā)生的原因是或者具有ip地址的機器不能找到(也就是說從當前機器不存在到指定ip路由),或者是該ip存在,但找不到指定的端口進行監(jiān)聽。出現(xiàn)該問題,首先檢查客戶端的ip和port是否寫錯了,如果正確則從客戶端ping一下服務器看是否能ping通,如果能ping通(服務服務器端把ping禁掉則需要另外的辦法),則看在服務器端的監(jiān)聽指定端口的程序是否啟動,這個肯定能解決這個問題。

第3個異常是java.net.SocketException: Socket is closed,

該異常在客戶端和服務器均可能發(fā)生。異常的原因是己方主動關(guān)閉了連接后(調(diào)用了Socket的close方法)再對網(wǎng)絡連接進行讀寫操作。

第4個異常是java.net.SocketException: (Connection reset或者Connect reset by peer:Socket write error)。

該異常在客戶端和服務器端均有可能發(fā)生,引起該異常的原因有兩個,***個就是如果一端的Socket被關(guān)閉(或主動關(guān)閉或者因為異常退出而引起的關(guān)閉),另一端仍發(fā)送數(shù)據(jù),發(fā)送的***個數(shù)據(jù)包引發(fā)該異常(Connect reset by peer)。另一個是一端退出,但退出時并未關(guān)閉該連接,另一端如果在從連接中讀數(shù)據(jù)則拋出該異常(Connection reset)。簡單的說就是在連接斷開后的讀和寫操作引起的。

第5個異常是java.net.SocketException: Broken pipe。

該異常在客戶端和服務器均有可能發(fā)生。在第4個異常的***種情況中(也就是拋出 SocketExcepton:Connect reset by peer:Socket write error后),如果再繼續(xù)寫數(shù)據(jù)則拋出該異常。前兩個異常的解決方法是首先確保程序退出前關(guān)閉所有的網(wǎng)絡連接,其次是要檢測對方的關(guān)閉連接操作,發(fā)現(xiàn)對方關(guān)閉連接后自己也要關(guān)閉該連接。

編寫網(wǎng)絡程序時需要注意的問題

第1個問題是要正確區(qū)分長、短連接。所謂的長連接是一經(jīng)建立就***保持。短連接就是在以下場景下,準備數(shù)據(jù)—>建立連接— >發(fā)送數(shù)據(jù)—>關(guān)閉連接。很多的程序員寫了多年的網(wǎng)絡程序,居然不知道什么是長連接,什么是短連接。

第2個問題是對長連接的維護。所謂的維護包括兩個方面,首先是檢測對方的主動斷連(既調(diào)用 Socket的close方法),其次是檢測對方的宕機、異常退出及網(wǎng)絡不通。這是一個健壯的通信程序必須具備的。檢測對方的主動斷連很簡單,主要一方主動斷連,另一方如果在進行讀操作,則此時的返回值只-1,一旦檢測到對方斷連,則應該主動關(guān)閉己方的連接(調(diào)用Socket的close方法)。

而檢測對方的宕機、異常退出及網(wǎng)絡不通常用方法是用“心跳”,也就是雙方周期性的發(fā)送數(shù)據(jù)給對方,同時也從對方接收“心跳”,如果連續(xù)幾個周期都沒有收到對方心跳,則可以判斷對方或者宕機或者異常推出或者網(wǎng)絡不通,此時也需要主動關(guān)閉己方連接,如果是客戶端可在延遲一定時間后重新發(fā)起連接。雖然Socket有一個keep alive選項來維護連接,如果用該選項,一般需要兩個小時才能發(fā)現(xiàn)對方的宕機、異常退出及網(wǎng)絡不通。

第3個問題是處理效率問題。不管是客戶端還是服務器,如果是長連接一個程序至少需要兩個線程,一個用于接收數(shù)據(jù),一個用于發(fā)送心跳,寫數(shù)據(jù)不需要專門的線程,當然另外還需要一類線程(俗稱Worker線程)用于進行消息的處理,也就是說接收線程僅僅負責接收數(shù)據(jù),然后再分發(fā)給Worker進行數(shù)據(jù)的處理。如果是短連接,則不需要發(fā)送心跳的線程,如果是服務器還需要一個專門的線程負責進行連接請求的監(jiān)聽。這些是一個通信程序的整體要求,具體怎么設(shè)計你的程序,就看你自己的設(shè)計水平了。

 

責任編輯:張浩 來源: 博客園
相關(guān)推薦

2010-04-23 15:54:19

桌面虛擬化

2024-10-31 11:52:05

緩存預熱系統(tǒng)

2012-05-10 18:20:05

戴爾

2013-07-03 14:43:44

戴爾軟件

2009-07-23 13:47:46

ASP.NET數(shù)據(jù)緩存

2014-07-11 16:02:01

思杰

2021-04-15 11:11:38

華為OneStorage

2012-01-09 16:37:36

點心解決方案

2010-02-05 15:54:37

IBM Power

2010-09-09 10:11:11

無線網(wǎng)絡故障

2013-07-12 18:29:56

戴爾

2011-12-19 16:02:56

無線網(wǎng)絡網(wǎng)絡故障

2023-09-06 16:49:14

架構(gòu)微服務

2014-11-11 10:48:44

華為eLTE

2012-01-11 10:55:02

ASP.NET MVC

2020-12-31 10:01:08

戴爾

2018-07-20 08:41:19

無服務器人工智能編程

2010-04-29 10:36:54

Server 2008打印服務器

2013-09-16 10:31:46

IBM System X86System x

2014-06-10 10:01:09

HttpClientClose_Wait
點贊
收藏

51CTO技術(shù)棧公眾號