這篇文章主要介紹了Java網(wǎng)絡(luò)通信中ServerSocket如何優(yōu)化,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)公司長期為千余家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為雙峰企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),雙峰網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
前言:在java的網(wǎng)絡(luò)通信中,兩個(gè)不同節(jié)點(diǎn)的主機(jī)想要進(jìn)行通信則可以通過建立Socket對象(相當(dāng)于客戶端主機(jī),向服務(wù)端請求發(fā)送信息)和ServerSocket對象(相當(dāng)于服務(wù)端主機(jī),接收客戶端的連接請求并回復(fù)信息)實(shí)現(xiàn)。
1:創(chuàng)建一個(gè)Socket對象
Socket socket = new Socket("IP",port);
指定將要連接的服務(wù)端的ip地址和端口號(hào)來創(chuàng)建一個(gè)Socket對象,在創(chuàng)建結(jié)束之后便可對其進(jìn)行輸出、輸入操作。
2:創(chuàng)建一個(gè)ServerSocket對象
ServerSocket sever = new ServerSocket(port); //此端口為客戶端連接的端口 Socket connnection = server.accept(); //阻塞在此監(jiān)聽上方的端口,一但有連接請求就做出處理。
創(chuàng)建一個(gè)新的ServerSocket對象,并讓這個(gè)對象阻塞監(jiān)聽客戶端連接的指定的端口,一但有新的連接請求則做出處理。
基本的一個(gè)關(guān)系是:Socket ------------------->ServerSocket
此時(shí)只要來一個(gè)連接服務(wù)端就阻塞做出處理,等到處理結(jié)束之后重新處以監(jiān)聽端口狀態(tài),要是又來一個(gè)新的連接請求則......一直往復(fù)處理動(dòng)作。明顯的缺點(diǎn)是效率低,每次只能處理一個(gè)請求,并且是阻塞處理狀態(tài)。
優(yōu)化處理:
BIO中開啟多線程,每來一個(gè)請求服務(wù)端就開啟一個(gè)線程處理。(優(yōu)點(diǎn)是可以提高效率,但是缺點(diǎn)也很明顯:優(yōu)點(diǎn)大量幾乎同時(shí)入站連接可能導(dǎo)致它生成極大數(shù)量的線程。最終,java虛擬機(jī)會(huì)消耗內(nèi)存二崩潰)。
對于上面的方案做出改進(jìn):BIO中使用線程池管理線程。(可以處理效率同時(shí)避免了服務(wù)器因?yàn)楦卟l(fā)的連接而崩潰)。
使用NIO。(NIO雖然也是單個(gè)線程去處理連接請求,但是不會(huì)阻塞,會(huì)不停地輪詢是否有就緒的事件,所以處理的順序和連接請求的先后順序無關(guān),與請求數(shù)據(jù)到來的先后順序有關(guān)。一個(gè)線程中就可以調(diào)用多路復(fù)用接口(select)阻塞同時(shí)監(jiān)聽來自多個(gè)客戶端的IO請求,一旦有收到IO請求就調(diào)用對應(yīng)函數(shù)處理)
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Java網(wǎng)絡(luò)通信中ServerSocket如何優(yōu)化”這篇文章對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!