socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)
前言
Web端與服務(wù)器間的實(shí)時(shí)數(shù)據(jù)傳輸?shù)氖且粋€(gè)很重要的需求,但最早只能通過(guò)AJAX輪詢(xún)?cè)儗?shí)現(xiàn)。在WebSocket標(biāo)準(zhǔn)沒(méi)有推出之前,AJAX輪詢(xún)是唯一可行的方式(通過(guò)Flash瀏覽器也可以,但這里不做討論)。AJAX輪詢(xún)?cè)硎窃O(shè)置定時(shí)器,定時(shí)通過(guò)AJAX同步服務(wù)器數(shù)據(jù)。這種方式存在延時(shí)且對(duì)服務(wù)端造成很大負(fù)載。直到2011年,IETF才標(biāo)準(zhǔn)化WebSocket——一種基于TCP套接字進(jìn)行收發(fā)數(shù)據(jù)的協(xié)議?,F(xiàn)如今主流瀏覽器均已支持WebSocket。
socket.io將數(shù)據(jù)傳輸部分獨(dú)立出來(lái)形成了engine.io , engine.io對(duì)WebSocket和AJAX輪詢(xún)進(jìn)行封裝,形成一套API,屏蔽了細(xì)節(jié)差異和兼容性問(wèn)題,實(shí)現(xiàn)了跨瀏覽器/跨設(shè)備進(jìn)行雙向數(shù)據(jù)。
socket.io對(duì)engine.io不是必須的,你也可以實(shí)現(xiàn)自己的engine.io,通過(guò)server.bind
綁定
應(yīng)用
- 實(shí)時(shí)數(shù)據(jù)分析展示(報(bào)表,日志)
- 即時(shí)通訊、聊天,
- 二進(jìn)制流(圖片,音樂(lè),視頻)傳輸
- 多人協(xié)同編輯
- 即時(shí)消息推送
類(lèi)似技術(shù)
- AJAX輪詢(xún): 基于XMLHttpRequest的AJAX輪詢(xún)
- AJAX長(zhǎng)輪詢(xún): 類(lèi)似輪詢(xún),服務(wù)器在客戶(hù)端請(qǐng)求后不返回響應(yīng),直到有數(shù)據(jù)需要傳到客戶(hù)端,傳完數(shù)據(jù)后客戶(hù)端再發(fā)起新的請(qǐng)求。缺點(diǎn)是要額外傳輸?shù)腍TTP頭,保持住請(qǐng)求不響應(yīng)也需要一些額外工作。
- HTTP流: 與AJAX長(zhǎng)輪詢(xún)類(lèi)似,服務(wù)端響應(yīng)會(huì)帶上HTTP頭:
Transfer-Encoding: chunked
,返回完數(shù)據(jù)到客戶(hù)端后客戶(hù)端也不需要發(fā)起新的請(qǐng)求,缺點(diǎn)是各個(gè)chunk之間的數(shù)據(jù)難以識(shí)別和處理。 - 插件: 類(lèi)似Flash,Silverlight, 作為插件越來(lái)越被主流瀏覽器和用戶(hù)排斥
下面就不同角度對(duì)各技術(shù)進(jìn)行分析
- 單向/雙向
- 單向: AJAX輪詢(xún),AJAX長(zhǎng)輪詢(xún),HTTP流
- 雙向: WebSocket, 插件
- 延時(shí)
WebSocket < 插件 < HTTP流 < AJAX長(zhǎng)輪詢(xún) < AJAX輪詢(xún)
1、效率
插件 > WebSocket > HTTP流 > AJAX長(zhǎng)輪詢(xún) > AJAX輪詢(xún)
1、移動(dòng)端支持
WebSocket: 基本均支持
HTTP流,AJAX長(zhǎng)輪詢(xún),AJAX輪詢(xún): 基本均支持
插件: 基本不支持
1、開(kāi)發(fā)或設(shè)置難易程度
WebSocket < AJAX輪詢(xún) < 插件 < AJAX長(zhǎng)輪詢(xún),HTTP流
總結(jié)
socket.io封裝了WebSocket,不支持WebSocket的情況還提供了降級(jí)AJAX輪詢(xún),功能完備,設(shè)計(jì)優(yōu)雅,是開(kāi)發(fā)實(shí)時(shí)雙向通訊的不二手段。
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- socket.io學(xué)習(xí)教程之基本應(yīng)用(二)
- node.js中的Socket.IO使用實(shí)例
- node.js中Socket.IO的進(jìn)階使用技巧
- 基于socket.io和node.js搭建即時(shí)通信系統(tǒng)
- node.js中的socket.io入門(mén)實(shí)例
- 使用Angular和Nodejs、socket.io搭建聊天室及多人聊天室
- node中socket.io的事件使用詳解
- node.js中使用socket.io的方法
- node.js中的socket.io的廣播消息
- socket.io學(xué)習(xí)教程之深入學(xué)習(xí)篇(三)
相關(guān)文章
Nodejs使用express 編寫(xiě)接口的實(shí)現(xiàn)
express是一個(gè)第三方模塊,支持豐富的api,本文主要介紹了Nodejs使用express 編寫(xiě)接口的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06NodeJS如何優(yōu)雅的實(shí)現(xiàn)Sleep休眠
這篇文章主要介紹了NodeJS如何優(yōu)雅的實(shí)現(xiàn)Sleep休眠問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09利用Node轉(zhuǎn)換Excel成JSON的詳細(xì)步驟
最近工作中遇到一個(gè)需求,大致需求就是將Excel文件在導(dǎo)入時(shí)解析為json格式轉(zhuǎn)換數(shù)據(jù)結(jié)構(gòu)再傳輸給后臺(tái),下面這篇文章主要給大家介紹了關(guān)于如何利用Node轉(zhuǎn)換Excel成JSON的詳細(xì)步驟,需要的朋友可以參考下2022-11-11解決Node.js包管理器安裝報(bào)錯(cuò)npm?ERR!?code?1的問(wèn)題
在開(kāi)發(fā)過(guò)程中,我們經(jīng)常需要使用各種Node.js包來(lái)擴(kuò)展我們的應(yīng)用程序功能,這些包通常通過(guò)npm(Node.js包管理器)進(jìn)行安裝和管理,有時(shí)候我們可能會(huì)遇到一些關(guān)于npm的錯(cuò)誤,本文將詳細(xì)介紹如何解決這個(gè)問(wèn)題,并提供一個(gè)詳細(xì)的實(shí)例,需要的朋友可以參考下2024-03-03Node.js實(shí)現(xiàn)大文件斷點(diǎn)續(xù)傳示例詳解
這篇文章主要為大家介紹了Node.js實(shí)現(xiàn)大文件斷點(diǎn)續(xù)傳示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11node.js中的fs.appendFile方法使用說(shuō)明
這篇文章主要介紹了node.js中的fs.appendFile方法使用說(shuō)明,本文介紹了fs.appendFile方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12