WebSocket笔记(一) 初步认识
使用場景
- 服務器,需要向客戶端主動端推送消息(數據)
- 客戶端,需要實施獲取服務器上數據更新或變化
基本概念
WebSocket是一種能在單個TCP連接上進行全雙工通訊的協議。
特點
較少的控制開銷
在連接創建后,服務器和客戶端之間交換數據時,用于協議控制的數據包頭部相對較小。在不包含擴展的情況下,對于服務器到客戶端的內容,此頭部大小只有2至10字節(和數據包長度有關);對于客戶端到服務器的內容,此頭部還需要加上額外的4字節的掩碼。相對于HTTP請求每次都要攜帶完整的頭部,此項開銷顯著減少了。
更強的實時性
由于協議是全雙工的,所以服務器可以隨時主動給客戶端下發數據。相對于HTTP請求需要等待客戶端發起請求服務端才能響應,延遲明顯更少;即使是和Comet等類似的長輪詢比較,其也能在短時間內更多次地傳遞數據。
保持連接狀態
與HTTP不同的是,Websocket需要先創建連接,這就使得其成為一種有狀態的協議,之后通信時可以省略部分狀態信息。而HTTP請求可能需要在每個請求都攜帶狀態信息(如身份認證等)。
更好的二進制支持
Websocket定義了二進制幀,相對HTTP,可以更輕松地處理二進制內容。
可以支持擴展
Websocket定義了擴展,用戶可以擴展協議、實現部分自定義的子協議。如部分瀏覽器支持壓縮等。
更好的壓縮效果
相對于HTTP壓縮,Websocket在適當的擴展支持下,可以沿用之前內容的上下文,在傳遞類似的數據時,可以顯著地提高壓縮率。
沒有跨域問題
不同于HTTP,WebSocket并沒有同源限制,客戶端可以與任意服務器通信
與 HTTP 協議有著良好的兼容性
默認端口同HTTP/HTTPs,也是80和443
握手階段采用 HTTP 協議,因此握手時不容易屏蔽,能通過各種 HTTP 代理服務器。
| 協議標識 | http/https | ws/wss |
| 端口 | 80/443 | 80/443 |
普通80端口:ws://example.com:80/some/path
加密443端口:wss://example.com:80/some/path
服務器端容易實現
Java/Python/Node/Php/.NET,好像都是支持的(表示心虛,我只是百度了一圈,都能找到現成解決方案)
參考文章
參考文章
維基百科 WebSocketWebSocket 教程(阮一峰)
WebSocket資料總結
websocket與comet的性能對比
淺談HTTP長連接
WEB通訊技術之短輪詢、長輪詢(comet)、長連接(SSE)、WebSocket
總結
以上是生活随笔為你收集整理的WebSocket笔记(一) 初步认识的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 计数原理,递推,求从左边能看到l个棒子,
- 下一篇: 7-7 六度空间(30 分)