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

B/S(Web)實時通訊解決方案分享

 更新時間:2017年04月06日 11:22:51   作者:lining.name  
這篇文章主要為大家分享了B/S(Web)實時通訊的解決方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下

B/S的實時通訊實現(xiàn)起來比較麻煩,因為http協(xié)議是無狀態(tài)的,導致一些實時消息通知和聊天等功能比較難以實現(xiàn),本文主要簡述幾種自己之前常用的幾種方式。

1、傳統(tǒng)的HTTP協(xié)議是無狀態(tài)的

傳統(tǒng)的HTTP協(xié)議是無狀態(tài)的,每次請求(request)都要由客戶端(如 瀏覽器)主動發(fā)起,服務(wù)端進行處理后返回response結(jié)果,而服務(wù)端很難主動向客戶端發(fā)送數(shù)據(jù),多個用戶進行實時的交流也比較困難,比如聊天系統(tǒng)。

2、目前比較流量的實時通訊方式

輪詢

條件:任何Web端

客戶端定時向服務(wù)器發(fā)送Ajax請求,服務(wù)器接到請求后馬上返回響應(yīng)信息并關(guān)閉連接。

長輪詢

條件:任何Web端

客戶端向服務(wù)器發(fā)送Ajax請求,服務(wù)器接到請求后hold住連接,直到有新消息才返回響應(yīng)信息并關(guān)閉連接,客戶端處理完響應(yīng)信息后再向服務(wù)器發(fā)送新的請求。

Flash socket

條件:需要安裝Flash插件

在頁面中內(nèi)嵌入一個使用了Socket類的 Flash 程序JavaScript通過調(diào)用此Flash程序提供的Socket接口與服務(wù)器端的Socket接口進行通信,JavaScript在收到服務(wù)器端傳送的信息后控制頁面的顯示。

Web Socket

條件:支持H5 Web socket

WebSocket protocol 是HTML5一種新的協(xié)議。它實現(xiàn)了瀏覽器與服務(wù)器全雙工通信(full-duple)。一開始的握手需要借助HTTP請求完成。

3、B/S 實時通訊輪詢方式

3.1傳統(tǒng)輪詢

客戶端定時向服務(wù)器發(fā)送Ajax請求,服務(wù)器接到請求后馬上返回響應(yīng)信息并關(guān)閉連接。

缺點:耗費資源,耗費流量 。根據(jù)用戶窗口數(shù)量,請求次數(shù)成倍的增加。

3.2 傳統(tǒng)長輪詢

客戶端向服務(wù)器發(fā)送Ajax請求,服務(wù)器接到請求后hold住鏈接,直到有新消息才返回響應(yīng)信息并關(guān)閉連接,客戶端處理完響應(yīng)信息后再向服務(wù)器發(fā)送新的請求。

由于瀏覽器同時只能有一定數(shù)量的鏈接同時hold,所有這種方式如果窗口打開多個,就會導致后面打開的窗口一直等待前面hold的鏈接。

3.3傳統(tǒng)長輪詢+ActiveMq

ActiveMq的方式相比傳統(tǒng)的查詢數(shù)據(jù)庫有一定的優(yōu)勢,這樣減少了多次查詢數(shù)據(jù)庫的問題,效率也會有所提升。但是這種方式每個用戶的每個窗口都會有個訂閱和鏈接,這樣導致ActiveMq服務(wù)器的鏈接數(shù)會隨著用戶的增加而增加,最后導致鏈接數(shù)沾滿。

4、ASP.NETSignalR

很明顯輪詢的方式并不是最好的解決方式,當然web socket是一種很好的實現(xiàn)方式,但是編程起來比較麻煩,由于lz是做.net開發(fā),所以選擇了ASP.NET SignalR。而且SignalR會兼容各種瀏覽器,如果瀏覽器支持web socket,則用web socket方式,如果不支持則用長輪詢的方式實現(xiàn)。

ASP.NET SignalR 是為 ASP.NET 開發(fā)人員提供的一個庫,可以簡化開發(fā)人員將實時 Web 功能添加到應(yīng)用程序的過程。實時 Web 功能是指這樣一種功能:當所連接的客戶端變得可用時服務(wù)器代碼可以立即向其推送內(nèi)容,而不是讓服務(wù)器等待客戶端請求新的數(shù)據(jù)。即你有信息了再來通知我,而不是我傻乎乎的每次跑來問你。

http://signalr.net/

4.1 SignalR 簡單編程

SignalR的配置以及應(yīng)用詳情可以參數(shù)官方文檔,這里只做簡單的發(fā)送消息和接收消息的示例。

1、客戶端發(fā)送消息至服務(wù)端

2、服務(wù)端發(fā)送消息至客戶端

在服務(wù)端向客戶端發(fā)送消息時可以選擇三種發(fā)送方式

1、All:所有頁面,比如:實時股票信息。

  Clients.All.xx();

2、Client:單個頁面,比如:聊天系統(tǒng)。

  Clients.Client("connectionId").xx();

3、Group:組,比如:同一個用戶所有頁面收到通知。

  Clients.Group("groupName").xx();

更多關(guān)于SignalR的詳情介紹,和實現(xiàn)群聊功能,可以參考另一篇 應(yīng)用并實現(xiàn)群聊功能 開源代碼

4.2 SignalR+數(shù)據(jù)庫

這種方式解決了用戶多個窗口不能收到消息的問題,而且數(shù)據(jù)庫的刷新頻率只會有一個線程刷新,并不會隨著用戶的增加而增加,從而大大的減小了數(shù)據(jù)庫的刷新頻率。

4.3SignalR+ActiveMq(最終解決方式)

這種方式既解決了鏈接數(shù)的問題,也同時解決了用戶多個窗口不能收到消息的問題,而且用了ActiveMq也不用去實時刷新數(shù)據(jù)庫。

結(jié)語

以上是lz在開發(fā)中應(yīng)用的多種B/S實時通信的解決方案,望對各位有所幫助,本文原創(chuàng),歡迎拍磚和推薦。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Fullpage.js固定導航欄-實現(xiàn)定位導航欄

    Fullpage.js固定導航欄-實現(xiàn)定位導航欄

    FullPage.js 是一個簡單而易于使用的插件,用來創(chuàng)建全屏滾動網(wǎng)站(也被稱為單頁網(wǎng)站)。接下來通過本文給大家介紹Fullpage.js固定導航欄-實現(xiàn)定位導航欄,對fullpage.js導航欄相關(guān)知識感興趣的朋友一起學習吧
    2016-03-03
  • JS獲取當前日期和時間的簡單實例

    JS獲取當前日期和時間的簡單實例

    這篇文章主要介紹了JS獲取當前日期和時間的簡單實例,有需要的朋友可以參考一下
    2013-11-11
  • JavaScript庫 開發(fā)規(guī)則

    JavaScript庫 開發(fā)規(guī)則

    1. 保持無侵入性,標記不想知道你的JavaScript代碼;2. 嚴禁修改和擴展Object.prototype!;3. 對JavaScript內(nèi)建對象的擴展越少越好;4. 跟隨標準;5. 或著跟隨主導 ;6. 保持靈活;7. 管理內(nèi)存;8. 淘汰瀏覽器嗅探;9. 小巧更佳……
    2009-01-01
  • 用js實現(xiàn)小球的自由移動代碼

    用js實現(xiàn)小球的自由移動代碼

    本篇文章小編為大家介紹,用js實現(xiàn)小球的自由移動代碼。需要的朋友參考下
    2013-04-04
  • 從延遲處理解析JavaScript惰性編程

    從延遲處理解析JavaScript惰性編程

    這篇文章主要為大家介紹了從延遲處理解析JavaScript惰性編程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 微信小程序request請求封裝,驗簽代碼實例

    微信小程序request請求封裝,驗簽代碼實例

    這篇文章主要介紹了微信小程序request請求封裝,驗簽代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • 中文字符串截取的js函數(shù)代碼

    中文字符串截取的js函數(shù)代碼

    有時在顯示某段文字的時候,可能會太長,影響我們頁面的顯示效果,如果僅是英文,那么我們可以用String.substring(start, end)函數(shù)就已經(jīng)夠用了,但是通常我們都會遇到既有英文,又有漢字的情況
    2013-04-04
  • JS判斷微信掃碼的方法

    JS判斷微信掃碼的方法

    這篇文章通過代碼給大家介紹了JS判斷是否是微信掃碼的方法,非常不錯,需要的朋友參考下吧
    2017-08-08
  • js添加類名的兩種方法

    js添加類名的兩種方法

    這篇文章主要介紹了js添加類名的兩種方法,一種是通過className來添加、刪除類名,另一種是通過classList來添加、刪除類名,感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • 利用Js+Css實現(xiàn)折紙動態(tài)導航效果實例源碼

    利用Js+Css實現(xiàn)折紙動態(tài)導航效果實例源碼

    這篇文章主要給大家介紹了利用Js+Css實現(xiàn)折紙動態(tài)導航的效果,實現(xiàn)后的效果非常不錯,文中給出了簡單的介紹和完整的實例代碼,對大家具有一定的參考價值,有需要的朋友們下面來一起看看吧。
    2017-01-01

最新評論