websocket的介紹
十多年的慈溪網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。營銷型網(wǎng)站建設(shè)的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整慈溪建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)從事“慈溪網(wǎng)站設(shè)計”,“慈溪網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
在講解WebSocket前,我們先來看看下面這種場景,在HTTP協(xié)議下,怎么實現(xiàn)。
需求:
在網(wǎng)站中,要實現(xiàn)簡單的聊天,這種情況怎么實現(xiàn)呢?如下圖:
當發(fā)送私信的時候,如果要求實時同步的話,可以先讓消息入庫,等對方登陸之后,查詢顯示即可。如下圖:
可是現(xiàn)在,需要實時消息,怎么辦?
最簡單的一種方式,就是寫個定時任務,輪詢查詢?nèi)?。如下圖:
雖然這樣可以實現(xiàn),我們可以看到,每隔一定時間,就會去調(diào)用服務器接口,查詢一次。這樣很浪費系統(tǒng)資源的。我們來看看HTTP協(xié)議:
如上圖:
客戶端和服務器建立連接后,發(fā)送請求數(shù)據(jù)給服務器;
服務器接收請求后,處理完成并更加請求返回響應的呼作為回應;
客戶端得到數(shù)據(jù)后,與服務器斷開連接。
這就是HTTP三次握手。是基于TCP/IP的
從上圖中,我們可以看到,http協(xié)議是典型的拉取方式,短鏈接的;是客戶端向服務器拉取數(shù)據(jù)的。如果,客戶端不發(fā)送請求,那么服務器的數(shù)據(jù)就不會主動給客戶的的。
我們的需求是要實現(xiàn)即時聊天的。因為要即時,所以,不能考客戶端拉取數(shù)據(jù),就需要使用服務器主動給客戶端推送數(shù)據(jù)的。就需要客戶端和服務器實時保持著聯(lián)系,也就是長連接。這種情況下,我們應該使用哪種技術(shù)來實現(xiàn)呢?實現(xiàn)方式有很多種,這里我們就用websocket來實現(xiàn)。
本文來源:凱哥Java(kaigejava)
我們來看看WebSocket介紹:
WebSocket 是HTML5一種新的協(xié)議。它實現(xiàn)了瀏覽器與服務器全雙工通信(full-duplex)。一開始的握手需要借助
HTTP請求完成。 WebSocket是真正實現(xiàn)了全雙工通信的服務器向客戶端推的互聯(lián)網(wǎng)技術(shù)。 它是一種在單個TCP連
接上進行全雙工通訊協(xié)議。Websocket通信協(xié)議與2011年倍IETF定為標準RFC 6455,Websocket API被W3C定為標準。
什么是全雙工?什么是單工?
全雙工(Full Duplex)是通訊傳輸?shù)囊粋€術(shù)語。通信允許數(shù)據(jù)在兩個方向上同時傳輸,它在能力上相當
于兩個單工通信方式的結(jié)合。全雙工指可以同時(瞬時)進行信號的雙向傳輸(A→B且B→A)。指
A→B的同時B→A,是瞬時同步的。
單工、半雙工(Half Duplex),所謂半雙工就是指一個時間段內(nèi)只有一個動作發(fā)生,舉個簡單例子,
一條窄窄的馬路,同時只能有一輛車通過,當目前有兩輛車對開,這種情況下就只能一輛先過,等到頭
兒后另一輛再開,這個例子就形象的說明了半雙工的原理。早期的對講機、以及早期集線器等設(shè)備都是基于半雙工的產(chǎn)品。隨著技術(shù)的不斷進步,半雙工會逐漸退出。
http與websocket的區(qū)別:
http:
通過上面講解,我們知道http協(xié)議是短鏈接,因為請求之后,都會關(guān)閉連接,下次重新請求數(shù)據(jù),需要再次打開鏈接。原理簡圖圖下:
websocket:
webSocket協(xié)議是一種長連接,只需要通過一次請求來初始化鏈接,然后所有的請求和響應都是通過這個TCP鏈接
進行通訊。簡單原理圖如下:
各大瀏覽器對websocket支持情況:
服務器要求:
服務器支持情況:Tomcat 7.0.47+以上才支持。
歡迎關(guān)注凱哥: