溫馨提示×

溫馨提示×

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

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

socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)

發(fā)布時(shí)間:2020-09-03 16:21:49 來源:腳本之家 閱讀:112 作者:sigoden 欄目:web開發(fā)

前言

Web端與服務(wù)器間的實(shí)時(shí)數(shù)據(jù)傳輸?shù)氖且粋€(gè)很重要的需求,但最早只能通過AJAX輪詢詢實(shí)現(xiàn)。在WebSocket標(biāo)準(zhǔn)沒有推出之前,AJAX輪詢是唯一可行的方式(通過Flash瀏覽器也可以,但這里不做討論)。AJAX輪詢原理是設(shè)置定時(shí)器,定時(shí)通過AJAX同步服務(wù)器數(shù)據(jù)。這種方式存在延時(shí)且對服務(wù)端造成很大負(fù)載。直到2011年,IETF才標(biāo)準(zhǔn)化WebSocket——一種基于TCP套接字進(jìn)行收發(fā)數(shù)據(jù)的協(xié)議?,F(xiàn)如今主流瀏覽器均已支持WebSocket。

socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)

socket.io將數(shù)據(jù)傳輸部分獨(dú)立出來形成了engine.io ,  engine.io對WebSocket和AJAX輪詢進(jìn)行封裝,形成一套API,屏蔽了細(xì)節(jié)差異和兼容性問題,實(shí)現(xiàn)了跨瀏覽器/跨設(shè)備進(jìn)行雙向數(shù)據(jù)。

socket.io對engine.io不是必須的,你也可以實(shí)現(xiàn)自己的engine.io,通過server.bind綁定

應(yīng)用

  • 實(shí)時(shí)數(shù)據(jù)分析展示(報(bào)表,日志)
  • 即時(shí)通訊、聊天,
  • 二進(jìn)制流(圖片,音樂,視頻)傳輸
  • 多人協(xié)同編輯
  • 即時(shí)消息推送

類似技術(shù)

  • AJAX輪詢: 基于XMLHttpRequest的AJAX輪詢
  • AJAX長輪詢: 類似輪詢,服務(wù)器在客戶端請求后不返回響應(yīng),直到有數(shù)據(jù)需要傳到客戶端,傳完數(shù)據(jù)后客戶端再發(fā)起新的請求。缺點(diǎn)是要額外傳輸?shù)腍TTP頭,保持住請求不響應(yīng)也需要一些額外工作。
  • HTTP流: 與AJAX長輪詢類似,服務(wù)端響應(yīng)會帶上HTTP頭: Transfer-Encoding: chunked,返回完數(shù)據(jù)到客戶端后客戶端也不需要發(fā)起新的請求,缺點(diǎn)是各個(gè)chunk之間的數(shù)據(jù)難以識別和處理。
  • 插件: 類似Flash,Silverlight, 作為插件越來越被主流瀏覽器和用戶排斥

下面就不同角度對各技術(shù)進(jìn)行分析

  • 單向/雙向
  • 單向: AJAX輪詢,AJAX長輪詢,HTTP流
  • 雙向: WebSocket, 插件
  • 延時(shí)

WebSocket < 插件 < HTTP流 < AJAX長輪詢 < AJAX輪詢

1、效率

插件 > WebSocket > HTTP流 > AJAX長輪詢 > AJAX輪詢

1、移動(dòng)端支持

WebSocket: 基本均支持

HTTP流,AJAX長輪詢,AJAX輪詢: 基本均支持

插件: 基本不支持

1、開發(fā)或設(shè)置難易程度

WebSocket < AJAX輪詢 < 插件 < AJAX長輪詢,HTTP流

總結(jié)

socket.io封裝了WebSocket,不支持WebSocket的情況還提供了降級AJAX輪詢,功能完備,設(shè)計(jì)優(yōu)雅,是開發(fā)實(shí)時(shí)雙向通訊的不二手段。

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細(xì)節(jié)

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

AI