【融云分析】選擇IM云服務,需要看哪些核心技術指標?

IM(即時通訊)云服務已發展數年,不少企業與開發者都傾向于選擇第三方IM云服務,短平快地為應用添加即時通訊能力,但如何選擇服務商卻是個難題,單從簡單的功能介紹來看無法判斷,因為IM云服務接入后,更重要的是檢驗服務是否穩定。近期艾瑞發布的《全球互聯網通信云行業研究報告》指出,通信云行業的競爭壁壘將在于核心技術關鍵指標,包括質量和性能指標。

IM領域,艾瑞認為核心質量指標為可靠性,即消息的不丟失和不重復。此外IM服務還需要考量并發處理能力等性能指標等。在艾瑞報告中,融云是被評定為IM領域市場占有率第一的互聯網通信云服務商,也是業內唯一承諾消息不丟、不重、不亂序的廠商。下面便來從技術上剖析下,融云利用了哪些手段實現穩定可靠的IM云服務。

?

一、基于融云私有通訊協議,實現服務的可靠性與安全性。

1.可靠性

即時通訊系統的可靠性體現在消息的可達率,也是IM最基本的質量要求:融云是業內唯一承諾消息可靠性100%的廠商。融云基于私有通訊協議,可實現:弱網環境下,消息發送方消息只要發送到服務器端,則服務器端能確保消息不丟、不亂、不重。

“不丟”是因為消息接收方客戶端與服務器端通過推拉相結合的方式,確保消息一定能收到接收方客戶端。“不亂”是因為在協議層面上針對每個數據包都做了序號標識處理。“不重”是當消息接收方收到消息后,因網絡問題導致消息收到的回執未能發送給服務器端,服務器端超時處理會進行消息的重發,當客戶端再次收到同一條消息時,會拋棄一條,只給用戶顯示一條。

2.安全性

基于融云自有知識產權的連接加密技術,可以防止黑客中間人方式進行數據竊聽,數據在傳輸過程中不可破解,NAV導航服務與CMP連接管理服務的安全算法一致,每個客戶端從導航服務獲取到加密校驗值(SM2標準),均按照安全算法與所連接的CMP服務進行安全協商,針對校驗值CMP會進行合法性驗證(SM3標準),協商的校驗值不能在其他CMP連接管理服務上使用,消息在傳輸之前,通過SM4對數據進行加密,并且通過加密連接傳輸將信息發送到發送方所在CMP連接管理服務。之后,由發送方所在CMP連接管理服務進行解密并將解密后的消息發給消息服務,依據協議內容,由消息服務負責將信息傳遞給接收方所在CMP連接管理服務,而后CMP連接管理服務依據接收方的密鑰進行信息加密,通過加密連接下發信息。

二、基于分布式微服務架構,保障億級高并發性。

對于IM云服務,海量消息并發的穩定性也至關重要,比如一些場景出現同時在線人數飆升,需要實現自動水平擴展,應對海量并發。融云IM云服務采用分布式的微服務架構可以實現億級消息的高并發,主要分為網關服務和應用服務兩大類,各服務通過Zookeeper完成服務注冊以及服務發現。所有的服務均可以采用集群化的方式部署,服務間的數據調用采用一致性哈希的方式進行集群負載。

?

1.服務的高可用性

服務節點通過Zookeeper在集群中同步自己節點狀態,各節點可以快速的發現其他節點變化。通過哈希算法的散列特性,可以將請求均勻的分配到應用節點上,以達到均衡服務器資源利用的目的。

當同一服務節點的個數為N+1(N>0)時,某一個服務節點發生關閉或宕機,其余節點會立刻收到問題節點的狀態變化通知,將其從一致性哈希環中將其剔除,后續請求將不會分配到此節點上,而剩余節點依然可以繼續提供服務。通過一致性哈希的特性,問題節點的請求可以均勻的分布到其他節點上,不會出現連鎖雪崩現象。

2.服務的可擴展性

“服務的啟動及發現流程”為例,所有的服務都可以在線添加。而服務完成注冊及發現流程后既可以對外提供服務。

三、基于全球多節點覆蓋,保障全球服務的穩定性

IM云服務依賴于廣域IP網絡進行實時消息傳遞,通信質量對網絡穩定性比較敏感,主要體現在網絡延時、網絡丟包和連通率等多方面。若實現跨地域跨國家的高質量通信,則需要降低網絡延時與網絡丟包的出現以及提高連接率。融云通過搭建全球通信加速網絡解決上述問題,通過專線網絡有效控制延遲、丟包等問題,以及搭建了更多的邊緣節點解決了地域連通率等問題。

融云在全球設立了多數據中心,具備3000多個加速點,通信網絡已經覆蓋全球所有國家及地區233個),可為客戶隨時隨地保障至少3個就近節點提供接入,少次跳轉就能鏈接到目的地,連接速度更快,連通效率更高。此外,通過海外鏈路優化,可實現更智能的鏈路調度,向客戶端同時提供多條可選鏈路,自動切換的解決模式,有效解決客戶通信跨地域、跨國家的“網絡延遲”及“丟包”等問題。通過實時監控全球網絡,基于融云分布全球的數據中心與節點建設,向客戶提供鏈路接入方案。

?

通過融云全球通信網絡加速,歐洲用戶直接訪問北美數據中心網絡延時一般在350~500ms之間,丟包率6%,網絡連接成功率只有90%;采用融云全球鏈路加速后,歐洲用戶直接訪問北美數據中心,網絡延時可縮短至200~250ms之間,丟包率幾乎為0,最高不超過0.1%;再借助融云全球智能動態網絡優化策略,網絡連接成功率可提升到99.5%以上。

結語IM即時通訊做不好將是一個填不完的“坑”,尤其是用戶量起來后,收發消息延遲等等各種問題都會出來,嚴重影響用戶的體驗,試錯成本也非常大。IM的穩定性背后需要廠商多年的技術積累,才能幫助用戶“坑”跳過去,實現一個穩定可靠的服務。目前市場上的服務很多,競爭越激烈,使用即時通訊云的企業或者開發者必須做到“火眼金睛”,對以上因素進行綜合性判斷,然后做出一個好的選型。

注冊融云賬號查看更多詳情

轉載于:https://www.cnblogs.com/rongcloud/p/11212188.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/448227.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/448227.shtml
英文地址,請注明出處:http://en.pswp.cn/news/448227.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Nginx 配置詳解

序言 Nginx是lgor Sysoev為俄羅斯訪問量第二的rambler.ru站點設計開發的。從2004年發布至今,憑借開源的力量,已經接近成熟與完善。 Nginx功能豐富,可作為HTTP服務器,也可作為反向代理服務器,郵件服務器。支持FastCGI…

protocol buffers使用說明

一、什么是protocol buffers Protocol buffers是一個靈活的、高效的、自動化的用于對結構化數據進行序列化的協議,與XML相比,Protocol buffers序列化后的碼流更小、速度更快、操作更簡單。你只需要將要被序列化的數據結構定義一次(譯注:使用…

jeeCMS首頁加載流程

版權聲明:本文為博主原創文章,未經博主允許不得轉載。 https://blog.csdn.net/gyshun/article/details/79669293 如果JEECMS部署完畢之后,在瀏覽器中輸入http://localhost:8080/jeecms,系統直接會按照以下步驟執行: 首…

車子突然溜坡追尾 駕校教練說掛P擋拉手剎不會溜坡

昨天4:44,朱先生來電:剛才登云路一個燒烤店門口,一輛車停在自己的車位上的,不知什么原因,突然溜坡撞上前面的一輛出租車。稀奇的是,這個溜坡的駕駛員全程都是車上睡覺睡著的,什么都不知道。記者…

VSCode 漢化、設置為 中文語言顯示 、中文界面

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 Vscode是一款開源的跨平臺編輯器。默認情況下,vscode使用的語言為英文(us),如何將其顯示語言修改成中文了&#…

c++執行vbs腳本

#include<fstream> using namespace std;int main() {fstream out("StartIE.vbs",ios::out);out<<"AppName\"啟動IE\"\n\Set WshellWScript.CreateObject(\"WScript.Shell\")\n\Set ieWScript.CreateObject(\"InternetEx…

Python-21-socket編程

一、基礎知識 1. C/S架構 C/S架構即客戶機/服務器模式。 它可以分為客戶機和服務器兩層&#xff1a; 第一層: 在客戶機系統上結合了界面顯示與業務邏輯&#xff1b; 第二層: 通過網絡結合了數據庫服務器。 簡單的說就是第一層是用戶表示層&#xff0c;第二層是數據庫層。 這里…

解決:VScode 漢化后 、設置中文后 還顯示英文的問題

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 按f1 搜索 Configore Display Language 設置 zh-cn 關閉軟件重啟。 如果重啟菜單等還是英文的&#xff0c;在商店查看已安裝的插件&…

自動擋怎么開-自動擋汽車怎么開?

汽車改用自動變速器后&#xff0c;駕駛員的操作更加簡便、駕駛更加平順&#xff0c;因此裝備自動變速器的新型轎車尤其受到了人們的青睞。不過&#xff0c;很多駕駛者初開自動擋車時&#xff0c;由于對自動變速器的結構和原理不是很了解&#xff0c;行車時經常是一個D擋走完全程…

CreateThread函數

創建一個在調用進程的虛擬地址空間內執行的線程。 要創建在另一個進程的虛擬地址空間中運行的線程&#xff0c;請使用 CreateRemoteThread函數。 語法 HANDLE CreateThread(LPSECURITY_ATTRIBUTES lpThreadAttributes,SIZE_T dwStackSize,LPTHREAD_START…

nginx 的請求處理、請求的處理流程

nginx的請求處理 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 nginx使用一個多進程模型來對外提供服務&#xff0c;其中一個master進程&#xff0c;多個worker進程。master進程負責…

如何控制油門更準確?

學員問&#xff1a;平時練車還不錯&#xff0c;可是一換車就容易加大油門&#xff0c;有什么方法能很好的控制油呢&#xff1f;&#xff1f; 如何控制油門更準確&#xff1f;和調的座位有關系嗎&#xff1f;&#xff1f; 答&#xff1a;油門跟剎車被視為汽車控制的靈魂。汽車發…

使用線程——創建線程

CreateThread函數創建一個進程的新的線程。創建線程必須指定新線程要執行的代碼的起始地址。通常&#xff0c;起始地址是程序代碼中定義的函數的名稱&#xff08;有關更多信息&#xff0c;請參閱ThreadProc&#xff09;。此函數采用單個參數并返回DWORD值。一個進程可以讓多個線…

location

location (地址)&#xff1a; 是瀏覽器 window 上的一個對象&#xff0c;不僅能處理當前頁面的網絡地址&#xff0c;還可以實現頁面間的跳轉 頁面的跳轉&#xff1a; 為什么使用它&#xff1f; 使我們也可以通過腳本語言&#xff0c;也能實現 a 鏈接&#xff0c;同樣的效果&…

linux :Docker 方式 安裝 zookeeper、阿里服務器上 Docker 運行 zookeeper

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1. 查找官方鏡像&#xff0c;并下載鏡像&#xff1a; # 搜索鏡像&#xff1a; docker search zookeeper# 拉取鏡像&#xff1a;docker …

使用線程池功能

此示例創建自定義線程池&#xff0c;創建工作項和線程池計時器&#xff0c;并將它們與清理組關聯。該池由一個持久性線程組成。它演示了以下線程池函數的使用&#xff1a; CloseThreadpool CloseThreadpoolCleanupGroupCloseThreadpoolCleanupGroupMembersCloseThreadpoolWait…

制動剎車片六個養護要點

剎車片屬于消耗品&#xff0c;在使用中會逐漸磨損&#xff0c;當磨損到極限位置時&#xff0c;必須更換&#xff0c;否則將降低制動的效果&#xff0c;甚至造成安全事故。 制動剎車片關乎生命安全&#xff0c;必須謹慎對待。 大多數轎車采用前盤后鼓式制動器結構&#xff0c;一…

Learn day4 函數參數\變量\閉包\遞歸

1.函數描述 # ### 函數 """ (1)函數的定義:功能 (包裹一部分代碼 實現某一個功能 達成某一個目的) (2)函數特點:可以反復調用,提高代碼的復用性,提高開發效率,便于維護管理 """# (3) 函數的基本格式 """ # 函數的定義處 def fun…

Java 中去除字符串中空格的方法

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1、方法分類 str.trim(); //去掉首尾空格str.replace(" ",""); //去除所有空格&#xff0c;包括首尾、中間str.re…

使用重定向的輸入和輸出創建子進程

本主題中的示例演示如何使用控制臺進程中的CreateProcess函數創建子進程。它還演示了一種使用匿名管道重定向子進程的標準輸入和輸出句柄的技術。請注意&#xff0c;命名管道也可用于重定向進程I / O. 所述CreatePipe函數使用SECURITY_ATTRIBUTES結構來創建可繼承句柄讀寫兩個…