溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java網(wǎng)絡通信中ServerSocket如何優(yōu)化

發(fā)布時間:2021-09-09 11:25:31 來源:億速云 閱讀:172 作者:小新 欄目:編程語言

這篇文章主要介紹了Java網(wǎng)絡通信中ServerSocket如何優(yōu)化,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

前言:在java的網(wǎng)絡通信中,兩個不同節(jié)點的主機想要進行通信則可以通過建立Socket對象(相當于客戶端主機,向服務端請求發(fā)送信息)和ServerSocket對象(相當于服務端主機,接收客戶端的連接請求并回復信息)實現(xiàn)。

1:創(chuàng)建一個Socket對象

Socket socket = new Socket("IP",port);

指定將要連接的服務端的ip地址和端口號來創(chuàng)建一個Socket對象,在創(chuàng)建結束之后便可對其進行輸出、輸入操作。

2:創(chuàng)建一個ServerSocket對象

ServerSocket sever = new ServerSocket(port); //此端口為客戶端連接的端口
Socket connnection = server.accept(); //阻塞在此監(jiān)聽上方的端口,一但有連接請求就做出處理。

創(chuàng)建一個新的ServerSocket對象,并讓這個對象阻塞監(jiān)聽客戶端連接的指定的端口,一但有新的連接請求則做出處理。

基本的一個關系是:Socket ------------------->ServerSocket

此時只要來一個連接服務端就阻塞做出處理,等到處理結束之后重新處以監(jiān)聽端口狀態(tài),要是又來一個新的連接請求則......一直往復處理動作。明顯的缺點是效率低,每次只能處理一個請求,并且是阻塞處理狀態(tài)。 

優(yōu)化處理:

  • BIO中開啟多線程,每來一個請求服務端就開啟一個線程處理。(優(yōu)點是可以提高效率,但是缺點也很明顯:優(yōu)點大量幾乎同時入站連接可能導致它生成極大數(shù)量的線程。最終,java虛擬機會消耗內存二崩潰)。

  • 對于上面的方案做出改進:BIO中使用線程池管理線程。(可以處理效率同時避免了服務器因為高并發(fā)的連接而崩潰)。

  • 使用NIO。(NIO雖然也是單個線程去處理連接請求,但是不會阻塞,會不停地輪詢是否有就緒的事件,所以處理的順序和連接請求的先后順序無關,與請求數(shù)據(jù)到來的先后順序有關。一個線程中就可以調用多路復用接口(select)阻塞同時監(jiān)聽來自多個客戶端的IO請求,一旦有收到IO請求就調用對應函數(shù)處理)

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Java網(wǎng)絡通信中ServerSocket如何優(yōu)化”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業(yè)資訊頻道,更多相關知識等著你來學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI