Java網(wǎng)絡(luò)通信中ServerSocket的設(shè)計(jì)優(yōu)化方案
前言:在java的網(wǎng)絡(luò)通信中,兩個(gè)不同節(jié)點(diǎn)的主機(jī)想要進(jìn)行通信則可以通過建立Socket對(duì)象(相當(dāng)于客戶端主機(jī),向服務(wù)端請(qǐng)求發(fā)送信息)和ServerSocket對(duì)象(相當(dāng)于服務(wù)端主機(jī),接收客戶端的連接請(qǐng)求并回復(fù)信息)實(shí)現(xiàn)。
1:創(chuàng)建一個(gè)Socket對(duì)象
Socket socket = new Socket("IP",port);
指定將要連接的服務(wù)端的ip地址和端口號(hào)來創(chuàng)建一個(gè)Socket對(duì)象,在創(chuàng)建結(jié)束之后便可對(duì)其進(jìn)行輸出、輸入操作。
2:創(chuàng)建一個(gè)ServerSocket對(duì)象
ServerSocket sever = new ServerSocket(port); //此端口為客戶端連接的端口 Socket connnection = server.accept(); //阻塞在此監(jiān)聽上方的端口,一但有連接請(qǐng)求就做出處理。
創(chuàng)建一個(gè)新的ServerSocket對(duì)象,并讓這個(gè)對(duì)象阻塞監(jiān)聽客戶端連接的指定的端口,一但有新的連接請(qǐng)求則做出處理。
基本的一個(gè)關(guān)系是:Socket ------------------->ServerSocket
此時(shí)只要來一個(gè)連接服務(wù)端就阻塞做出處理,等到處理結(jié)束之后重新處以監(jiān)聽端口狀態(tài),要是又來一個(gè)新的連接請(qǐng)求則......一直往復(fù)處理動(dòng)作。明顯的缺點(diǎn)是效率低,每次只能處理一個(gè)請(qǐng)求,并且是阻塞處理狀態(tài)。
優(yōu)化處理:
- BIO中開啟多線程,每來一個(gè)請(qǐng)求服務(wù)端就開啟一個(gè)線程處理。(優(yōu)點(diǎn)是可以提高效率,但是缺點(diǎn)也很明顯:優(yōu)點(diǎn)大量幾乎同時(shí)入站連接可能導(dǎo)致它生成極大數(shù)量的線程。最終,java虛擬機(jī)會(huì)消耗內(nèi)存二崩潰)。
- 對(duì)于上面的方案做出改進(jìn):BIO中使用線程池管理線程。(可以處理效率同時(shí)避免了服務(wù)器因?yàn)楦卟l(fā)的連接而崩潰)。
- 使用NIO。(NIO雖然也是單個(gè)線程去處理連接請(qǐng)求,但是不會(huì)阻塞,會(huì)不停地輪詢是否有就緒的事件,所以處理的順序和連接請(qǐng)求的先后順序無關(guān),與請(qǐng)求數(shù)據(jù)到來的先后順序有關(guān)。一個(gè)線程中就可以調(diào)用多路復(fù)用接口(select)阻塞同時(shí)監(jiān)聽來自多個(gè)客戶端的IO請(qǐng)求,一旦有收到IO請(qǐng)求就調(diào)用對(duì)應(yīng)函數(shù)處理)
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
Java使用iTextPDF生成PDF文件的實(shí)現(xiàn)方法
這篇文章主要介紹了Java使用iTextPDF生成PDF文件的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
SpringBoot整合Quartz及異步調(diào)用的案例
Quartz是一個(gè)完全由java編寫的開源作業(yè)調(diào)度框架、它的簡(jiǎn)單易用受到業(yè)內(nèi)人士的一致好評(píng),這篇文章主要介紹了SpringBoot整合Quartz及異步調(diào)用,需要的朋友可以參考下2023-03-03
Spring Boot處理全局統(tǒng)一異常的兩種方法與區(qū)別
這篇文章主要給大家介紹了關(guān)于Spring Boot處理全局統(tǒng)一異常的兩種方法與區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring Boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
Sa-Token不同模式實(shí)現(xiàn)單地登錄?多地登錄?同端互斥登錄
這篇文章主要為大家介紹了Sa-Token不同模式實(shí)現(xiàn)單地登錄?多地登錄?同端互斥登錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Kotlin中使用Java數(shù)據(jù)類時(shí)引發(fā)的Bug解決方式
這篇文章主要介紹了Kotlin中使用Java數(shù)據(jù)類時(shí)引發(fā)的一個(gè)Bug,本文給大家分享問題解決方式,感興趣的朋友跟隨小編一起看看吧2023-09-09
spring項(xiàng)目對(duì)某條單據(jù)進(jìn)行加鎖處理的方法
這篇文章主要給大家介紹了關(guān)于spring項(xiàng)目對(duì)某條單據(jù)進(jìn)行加鎖處理的相關(guān)資料,用于對(duì)工單單據(jù)進(jìn)行加鎖和解鎖處理,以防止多用戶同時(shí)編輯同一單據(jù),前端傳遞參數(shù)包括單據(jù)ID、類型、鎖超時(shí)時(shí)間等,后端通過Redis實(shí)現(xiàn)鎖機(jī)制,需要的朋友可以參考下2024-11-11
Java?Web開發(fā)常用框架Spring?MVC?Struts示例解析
這篇文章主要為大家介紹了Java?Web開發(fā)常用框架Spring?MVC?Struts示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
java調(diào)用ffmpeg實(shí)現(xiàn)轉(zhuǎn)換視頻
這篇文章主要為大家詳細(xì)介紹了java調(diào)用ffmpeg實(shí)現(xiàn)轉(zhuǎn)換視頻功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12

