欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java開(kāi)發(fā)中常用的 Websocket 技術(shù)參考

 更新時(shí)間:2020年09月14日 10:15:44   作者:碼農(nóng)小胖哥  
WebSocket 使得客戶端和服務(wù)器之間的數(shù)據(jù)交換變得更加簡(jiǎn)單,允許服務(wù)端主動(dòng)向客戶端推送數(shù)據(jù),當(dāng)然也支持客戶端發(fā)送數(shù)據(jù)到服務(wù)端。

1. 前言

Websocket是 HTML5 開(kāi)始提供的一種在單個(gè) TCP 連接上進(jìn)行全雙工通訊的協(xié)議。WebSocket 使得客戶端和服務(wù)器之間的數(shù)據(jù)交換變得更加簡(jiǎn)單,允許服務(wù)端主動(dòng)向客戶端推送數(shù)據(jù),當(dāng)然也支持客戶端發(fā)送數(shù)據(jù)到服務(wù)端。通常用來(lái)社交聊天、彈幕、多玩家游戲、協(xié)同編輯、股票基金實(shí)時(shí)報(bào)價(jià)、資訊自動(dòng)更新等場(chǎng)景,那么今天就簡(jiǎn)單聊一下在 Java 開(kāi)發(fā)中對(duì)Websocket的技術(shù)選型。

技術(shù)選型是結(jié)合自身業(yè)務(wù)選擇最適合的技術(shù)方案,并不存在褒貶。

2. 常用的 Websocket 技術(shù)

2.1 Java Websocket 規(guī)范

這是JavaEE提供的規(guī)范,在包javax.websocket下,包含客戶端 API 和服務(wù)端 API,服務(wù)端 API 完全依賴于客戶端 API,只是在其基礎(chǔ)上添加了一些功能,所以只需要導(dǎo)入服務(wù)端依賴即可。 具體實(shí)現(xiàn)需要 Web 容器、JavaEE 服務(wù)器或者框架提供。我們常用的 Web 容器Tomcat、Undertow等都支持。

優(yōu)點(diǎn):集成起來(lái)簡(jiǎn)單,原生的Java支持。

缺點(diǎn):和 Web 服務(wù)器等共享容器耦合度高,廣播、組播需要自行控制。并發(fā)量較低,調(diào)優(yōu)麻煩,存在兼容性問(wèn)題。

2.2 SockJS

SockJS是一個(gè)瀏覽器JavaScript庫(kù),對(duì)Websocket進(jìn)行了抽象。SockJS為您提供了一個(gè)一致的,跨瀏覽器的Javascript API,該 API 在瀏覽器和 Web 服務(wù)器之間創(chuàng)建了低延遲,全雙工,跨域的通信通道。SockJS嘗試首先使用本機(jī)WebSockets。如果失敗了,它將嘗試其它各種特定于瀏覽器的傳輸協(xié)議,例如xhr-streaming、Server sent events 以及長(zhǎng)輪詢等。通常也會(huì)配合STOMP(面向消息的簡(jiǎn)單文本協(xié)議)來(lái)簡(jiǎn)化其使用。其實(shí)Spring 的Websocket組件中采用的就是此協(xié)議。

優(yōu)點(diǎn):社區(qū)活躍,技術(shù)成熟,協(xié)議棧豐富,有全套 Spring 解決方案,兼容性強(qiáng),另外可以結(jié)合發(fā)布訂閱模式。

缺點(diǎn):需要對(duì) SockJS 和 STOMP 進(jìn)行學(xué)習(xí),斷線重連、心跳檢測(cè)、二進(jìn)制支持不好。

2.3 Socket.IO

Socket.IO 是一個(gè)基于 Node.js 的實(shí)時(shí)應(yīng)用程序框架,在即時(shí)通訊、通知與消息推送,實(shí)時(shí)分析等場(chǎng)景中有較為廣泛的應(yīng)用,但是它提供基于Netty的服務(wù)端實(shí)現(xiàn)以及客戶端實(shí)現(xiàn),同時(shí)支持Websocket和長(zhǎng)輪詢。除了Websocket的常用場(chǎng)景外,我們可以通過(guò)該組件實(shí)現(xiàn)安卓和IOS的消息推送。

優(yōu)點(diǎn):性能良好,支持廣播、組播,斷線重連、心跳檢測(cè)、二進(jìn)制。支持安卓和 IOS 平臺(tái)。社區(qū)活躍。

缺點(diǎn):需要自行封裝同 Spring 的集成,服務(wù)端并非社區(qū)維護(hù),資源消耗大。

2.4 ReactiveStream

一些反應(yīng)流規(guī)范和框架也對(duì)Websocket進(jìn)行了實(shí)現(xiàn)。Spring Webflux和RSocket就是其中的代表,目前官方已經(jīng)放出了一些相關(guān)的 DEMO。

優(yōu)點(diǎn):高吞吐量、高性能。

缺點(diǎn):技術(shù)比較新、學(xué)習(xí)資料少。

3. 總結(jié)

這里無(wú)法給出也不可能哪種更好的結(jié)論。如果業(yè)務(wù)量非常少而且非常急迫的話第一種可以嘗試一下。SockJS和Socket.IO的爭(zhēng)論點(diǎn)在于性能上后者要好一些,當(dāng)然資源也消耗大,對(duì)移動(dòng)端的推送功能支持更好一些。在Spring整合上以及全套解決方案上SockJS更具優(yōu)勢(shì)。如果追求高性能、高吞吐量的Websocket那么無(wú)疑反應(yīng)式更加合適,但是學(xué)習(xí)成本也相對(duì)較高。其它小眾的技術(shù)這里不做評(píng)測(cè),如果你有比較好的方案可留言討論。

附:性能基準(zhǔn)測(cè)試

以下是國(guó)外某論文在 2020 年對(duì)原生Websocket、SockJS、Socket.IO進(jìn)行的性能測(cè)試的一些關(guān)鍵指標(biāo)。

隨著客戶端的增多創(chuàng)建連接的耗時(shí)隨著客戶端連接增多接收消息的平均時(shí)間接收一條消息所消耗的連接數(shù)和重組的TCP分段數(shù)服務(wù)端內(nèi)存占用趨勢(shì)

以上就是Java開(kāi)發(fā)中Websocket的技術(shù)選型參考的詳細(xì)內(nèi)容,更多關(guān)于Java Websocket的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • zookeeper概述圖文詳解

    zookeeper概述圖文詳解

    今天小編就為大家分享一篇關(guān)于Zookeeper概述圖文詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • 使用Java Minio搭建自己的文件系統(tǒng)詳解

    使用Java Minio搭建自己的文件系統(tǒng)詳解

    這篇文章主要介紹了使用Java Minio搭建自己的文件系統(tǒng)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-09-09
  • SpringBoot集成geodesy實(shí)現(xiàn)距離計(jì)算功能

    SpringBoot集成geodesy實(shí)現(xiàn)距離計(jì)算功能

    Geodesy:大地測(cè)量學(xué)的神奇力量 Geodesy,又稱大地測(cè)量學(xué),是一門研究地球形狀、大小及其重力場(chǎng)的學(xué)科,在地球距離計(jì)算中,它扮演著至關(guān)重要的角色,故本文給大家介紹了SpringBoot集成geodesy實(shí)現(xiàn)距離計(jì)算功能,感興趣的朋友可以參考下
    2024-06-06
  • JavaWeb中的常用的請(qǐng)求傳參注解說(shuō)明

    JavaWeb中的常用的請(qǐng)求傳參注解說(shuō)明

    這篇文章主要介紹了JavaWeb中的常用的請(qǐng)求傳參注解說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Spring?Boot深入排查?java.lang.ArrayStoreException異常

    Spring?Boot深入排查?java.lang.ArrayStoreException異常

    這篇文章介紹了Spring?Boot深入排查?java.lang.ArrayStoreException異常,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • DoytoQuery中關(guān)于N+1查詢問(wèn)題解決方案詳解

    DoytoQuery中關(guān)于N+1查詢問(wèn)題解決方案詳解

    這篇文章主要為大家介紹了DoytoQuery中關(guān)于N+1查詢問(wèn)題解決方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Java中l(wèi)ogback?自動(dòng)刷新不生效的問(wèn)題解決

    Java中l(wèi)ogback?自動(dòng)刷新不生效的問(wèn)題解決

    本文主要介紹了Java中l(wèi)ogback?自動(dòng)刷新不生效的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • SpringBoot加載不出來(lái)application.yml文件的解決方法

    SpringBoot加載不出來(lái)application.yml文件的解決方法

    這篇文章主要介紹了SpringBoot加載不出來(lái)application.yml文件的解決方法,文中通過(guò)示例代碼講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作有一定的幫助,需要的朋友跟著小編來(lái)一起來(lái)學(xué)習(xí)吧
    2023-12-12
  • SpringBoot項(xiàng)目打包成war包并部署在tomcat上運(yùn)行的操作步驟

    SpringBoot項(xiàng)目打包成war包并部署在tomcat上運(yùn)行的操作步驟

    我們開(kāi)發(fā) SpringBoot 項(xiàng)目有時(shí)我們會(huì)需要打包成 war 包,放入外置的 Tomcat 中進(jìn)行運(yùn)行,或者使用工具idea直接啟動(dòng),便于開(kāi)發(fā)調(diào)試,本文給大家分享SpringBoot項(xiàng)目打包成war包并部署在tomcat上運(yùn)行的操作步驟,感興趣的朋友一起看看吧
    2024-03-03
  • Spring高級(jí)注解之@DependsOn詳解

    Spring高級(jí)注解之@DependsOn詳解

    這篇文章主要介紹了Spring高級(jí)注解之@DependsOn詳解,@DependsOn注解可以定義在類和方法上,意思是我這個(gè)組件要依賴于另一個(gè)組件,也就是說(shuō)被依賴的組件會(huì)比該組件先注冊(cè)到IOC容器中,需要的朋友可以參考下
    2024-01-01

最新評(píng)論