socket網(wǎng)絡(luò)編程的常見問題小結(jié)與注意事項

一忠藤、常見問題

1、.java.net.SocketException: (Connection reset或者Connect reset by peer:Socket write error)真竖。

該異常在客戶端和服務(wù)器端均有可能發(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)癣蟋。簡單的說就是由連接斷開后的讀和寫操作引起的透硝。

2、java.net.BindException:Address already in use: JVM_Bind疯搅。

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

3、java.net.SocketException: Socket is closed浴井。

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

4、java.net.ConnectException: Connection refused: connect厉碟。

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

5跨新、java.net.SocketException: Connection reset 或者Connect reset by peer:Socket write error富腊。

該異常在客戶端和服務(wù)器端均有可能發(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)龙优。簡單的說就是在連接斷開后的讀和寫操作引起的羊异。

對于服務(wù)器,一般的原因可以認為:

a) 服務(wù)器的并發(fā)連接數(shù)超過了其承載量彤断,服務(wù)器會將其中一些連接主動 Down 掉野舶。

b) 在數(shù)據(jù)傳輸?shù)倪^程中,瀏覽器或者接收客戶端關(guān)閉了瓦糟,而服務(wù)端還在向客戶端發(fā)送數(shù)據(jù)筒愚。

6、java.net.SocketException: Broken pipe菩浙。

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

二轧苫、注意事項

1、長短連接區(qū)分

所謂的長連接是指一經(jīng)建立就永久保持。短連接的情況是含懊,準備數(shù)據(jù)—>建立連接—>發(fā)送數(shù)據(jù)—>關(guān)閉連接身冬。很多的程序員寫了多年的網(wǎng)絡(luò)程序,居然不知道什么是長連接岔乔,什么是短連接酥筝。

2、長連接維護

維護包括兩個方面雏门,首先是檢測對方的主動斷連(即調(diào)用 Socket的close方法)嘿歌,其次是檢測對方的宕機、異常退出及網(wǎng)絡(luò)不通茁影。這是一個健壯的通信程序必須具備的宙帝。檢測對方的主動斷連很簡單,主要一方主動斷連募闲,另一方如果在進行讀操作步脓,則此時的返回值只-1,一旦檢測到對方斷連蝇更,則應(yīng)該主動關(guān)閉本端的連接(調(diào)用Socket的close方法)沪编。而檢測對方的宕機、異常退出及網(wǎng)絡(luò)不通年扩,常用方法是用“心跳”蚁廓,也就是雙方周期性的發(fā)送數(shù)據(jù)給對方,同時也從對方接收“心跳”厨幻,如果連續(xù)幾個周期都沒有收到對方心跳相嵌,則可以判斷對方宕機、異常退出或者網(wǎng)絡(luò)不通况脆,此時也需要主動關(guān)閉本端連接饭宾,如果是客戶端可在延遲一定時間后重新發(fā)起連接。雖然Socket有一個keep alive選項來維護連接格了,如果用該選項看铆,一般需要兩個小時才能發(fā)現(xiàn)對方的宕機、異常退出及網(wǎng)絡(luò)不通盛末。

3弹惦、處理效率。

不管是客戶端還是服務(wù)器悄但,如果是長連接一個程序至少需要兩個線程棠隐,一個用于接收數(shù)據(jù),一個用于發(fā)送心跳檐嚣,寫數(shù)據(jù)不需要專門的線程助泽,當然另外還需要一類線程(俗稱Worker線程)用于進行消息的處理,也就是說接收線程僅僅負責接收數(shù)據(jù),然后再分發(fā)給Worker進行數(shù)據(jù)的處理嗡贺。如果是短連接隐解,則不需要發(fā)送心跳的線程,如果是服務(wù)器還需要一個專門的線程負責進行連接請求的監(jiān)聽诫睬。這些是一個通信程序的整體要求厢漩,具體到你的程序中,就看你如何對程序進行優(yōu)化岩臣。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市宵膨,隨后出現(xiàn)的幾起案子架谎,更是在濱河造成了極大的恐慌,老刑警劉巖辟躏,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谷扣,死亡現(xiàn)場離奇詭異,居然都是意外死亡捎琐,警方通過查閱死者的電腦和手機会涎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瑞凑,“玉大人末秃,你說我怎么就攤上這事∽延” “怎么了练慕?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長技掏。 經(jīng)常有香客問我铃将,道長,這世上最難降的妖魔是什么哑梳? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任劲阎,我火速辦了婚禮,結(jié)果婚禮上鸠真,老公的妹妹穿的比我還像新娘悯仙。我一直安慰自己,他們只是感情好弧哎,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布雁比。 她就那樣靜靜地躺著,像睡著了一般撤嫩。 火紅的嫁衣襯著肌膚如雪偎捎。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音茴她,去河邊找鬼寻拂。 笑死,一個胖子當著我的面吹牛丈牢,可吹牛的內(nèi)容都是我干的祭钉。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼己沛,長吁一口氣:“原來是場噩夢啊……” “哼慌核!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起申尼,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤垮卓,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后师幕,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體粟按,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年霹粥,在試婚紗的時候發(fā)現(xiàn)自己被綠了灭将。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡后控,死狀恐怖庙曙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情浩淘,我是刑警寧澤矾利,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站馋袜,受9級特大地震影響男旗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜欣鳖,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一察皇、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泽台,春花似錦什荣、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蜕依,卻和暖如春桅锄,著一層夾襖步出監(jiān)牢的瞬間琉雳,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工友瘤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留翠肘,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓辫秧,卻偏偏與公主長得像束倍,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子盟戏,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 計算機網(wǎng)絡(luò)概述 網(wǎng)絡(luò)編程的實質(zhì)就是兩個(或多個)設(shè)備(例如計算機)之間的數(shù)據(jù)傳輸绪妹。 按照計算機網(wǎng)絡(luò)的定義,通過一定...
    蛋炒飯_By閱讀 1,210評論 0 10
  • 網(wǎng)絡(luò)編程 網(wǎng)絡(luò)編程對于很多的初學(xué)者來說柿究,都是很向往的一種編程技能喂急,但是很多的初學(xué)者卻因為很長一段時間無法進入網(wǎng)絡(luò)編...
    程序員歐陽閱讀 2,006評論 1 37
  • 1、TCP狀態(tài)linux查看tcp的狀態(tài)命令:1)笛求、netstat -nat 查看TCP各個狀態(tài)的數(shù)量2)、lso...
    北辰青閱讀 9,398評論 0 11
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理糕簿,服務(wù)發(fā)現(xiàn)探入,斷路器,智...
    卡卡羅2017閱讀 134,599評論 18 139
  • 1.要確立目標懂诗。 2.逼自己蜂嗽。 3.提前定計劃,瞻前顧后殃恒。(不能再當佛系少女了哦)
    tigerboy閱讀 151評論 0 0