XMPP
XMPP(全稱:Extensible Messaging and Presence Protocol,舊名Jabber[1],中文可譯為可延伸訊息和表示協定)是一種以XML為基礎的開放式即時通訊協定,是經由互聯網工程工作小組(IETF)通過的互聯網標準。
國際標準 | RFC 6120 (Core) (2011) RFC 6121 (IM & Presence) (2011) |
---|---|
規範發佈 | 1999年 |
使用於 | 即時通訊 |
官方網站 | xmpp |
歷史
Jeremie Miller於1998年開始了這個專案。第一個公開版本於2000年5月發行。這個專案的主要產品是jabberd,XMPP的伺服器端軟件。它既可以建立私人的XMPP網絡,也可以加入全球的公共XMPP網絡。XMPP的關鍵特色是,分散式的即時通訊系統,以及使用XML串流。
Jabber已經由IETF XMPP協定(RFC3920)標準化。
Jabber是一個開放原始碼形式組織產生的網絡即時通訊協定。XMPP原本是為即時通訊而量身定製,但由於XML Stanza本身是XML元素,在基於XML靈活發展的特性下,使得XMPP也可以適用其他方面,已經得到了IETF的批准。XMPP與IMPP、PRIM、SIP(SIMPLE)合稱四大IM協定主流,在此4大協定中,XMPP是最靈活的。
特色
優點
- 標準
- 互聯網工程工作小組(IETF)已經將Jabber的核心XML串流協定以XMPP之名,正式列為認可的即時通訊及Presence技術。而XMPP的技術規格已被定義在RFC 3920及RFC 3921。任何IM供應商在遵循XMPP協定下,都可與Google Talk實現連接。
- 證實可用
- 第一個Jabber(現在XMPP)技術是Jeremie Miller在1998年開發的,現在已經相當穩定;數以百計的開發者為XMPP技術而努力。今日的互聯網上有數以萬計的XMPP伺服器運作著,並有數以百萬計的人們使用XMPP即時傳訊軟件。
- 分散式
- XMPP網絡的架構和電子郵件十分相像;XMPP核心協定通訊方式是先建立一個stream,XMPP以TCP傳遞XML資料流,沒有中央主伺服器。任何人都可以運行自己的XMPP伺服器,使個人及組織能夠掌控他們的即時傳訊體驗。
- 彈性佳
- XMPP除了可用在即時通訊的應用程式,還能用在網絡管理、內容供稿、協同工具、檔案共用、遊戲、遠端系統監控等。
- 多樣性
- 用XMPP協定來建造及布署即時應用程式及服務的公司及開放原始碼計劃分佈在各種領域;用XMPP技術開發軟件,資源及支援的來源是多樣的,使得使你不會陷於被「綁架」的困境。
缺點
- 資料負載太重
- 隨着通常超過70%的XMPP協定的伺服器的資料流量的存在和近60%的被重複轉發,XMPP協定目前擁有一個大型架空中存在的資料提供給多個收件人。新的議定書正在研究,以減輕這一問題。
- 二進制資料傳輸受限
- XMPP傳輸單一的XML檔案,因此要透過XMPP傳輸二進制資料,需先將二進制資料以Base64編碼。但是大量的二進制資料傳輸,較佳的作法是用外部的其他協定傳輸,而以XMPP進行溝通。至於其他二進制資料加密會話(encrypted conversations)或圖形圖示(graphic icons)以嵌入式使用相同的方法。
運作方式
XMPP網絡是基於伺服器的(即客戶端之間彼此不直接交談),但是也是分散式的。不像AOL即時通或MSN Messenger等服務,XMPP沒有中央官方伺服器。Jabber.org的公眾伺服器上有大量的用戶,所以有些人誤解了,以為它是官方伺服器,不過事實上任何人都可以在自己的網域上運行XMPP伺服器。
Jabber識別符(JID)是用戶登入時所使用的帳號,看起來通常像一個電子郵件地址,如[email protected];前半部分為用戶名,後半部分為XMPP伺服器域名,兩個欄位以@符號區隔。
假設朱麗葉([email protected])想和羅密歐([email protected])通話,他們兩人的帳號分別在Capulet.com及Montague.net的伺服器上。當朱麗葉輸入訊息並按下傳送鈕之後,一連串的事件就發生了:
- 朱麗葉的XMPP客戶端將她的訊息傳送到Capulet.com XMPP伺服器。
- Capulet.com XMPP伺服器開啟與Montague.net XMPP伺服器的連接。
- Montague.net XMPP伺服器將訊息寄送給羅密歐。如果他目前不在線上,那麼儲存訊息以待稍後寄送。
|
|
|
|
羅密歐與朱麗葉兩人的XMPP服務是由兩家不同的業者所提供的,而他們彼此傳訊時,不須擁有對方伺服器的帳號,也不須成為對方業者的會員。
與其他協定互聯
XMPP協定的另一功能是運輸(transports),也被稱為網關(gateways),可允許用戶透過網絡使用其它協定。這可以是其他的即時通訊協定,也可以是不同協定,如短訊(SMS)或電子郵件。
XMPP協定通過HTTP運輸
在原來的規格,XMPP協定可以使用HTTP的方式有兩種:輪詢(polling)[3]與綁定(binding)[4]。輪詢現在不推薦,基本上,輪詢意味着HTTP郵件儲存在伺服器端的資料庫上,客戶端必須一再地以HTTP的GET和POST的方式去抓取(以及刊出)其中的訊息。然而使用綁定的方式時,客戶端會保留一個長存的HTTP連線,等待一旦伺服器有新的訊息時,就立刻接收訊息。因為輪詢的結果往往是伺服端沒有新訊息,這種推播的通知模式比輪詢的方式更有效率。
由於客戶端使用HTTP,大多數防火牆允許客戶端獲取和留言沒有任何障礙。因此,即使使用XMPP協定的TCP埠被攔截,伺服器也能正常地傾聽一般的HTTP埠,其上的訊息也能保持暢通。還有一些網站更允許大眾經由瀏覽器登入進XMPP。尤有甚者,還有一些公共的伺服器同時擁有標準HTTP(80埠)和HTTPS(443埠),因此又有助於通過防火牆。
使用實例
XMPP 伺服器的高容錯性和低開銷[5]使得許多大公司使用 XMPP 作為其基礎平台來建立私人信使和聊天,以及提供推播通知[6]。
- WhatsApp ~8 億用戶,使用修改後的XMPP協定進行聊天
- 藝電 ~4000 萬用戶,使用XMPP進行聊天
- Nintendo Switch NPNS ~3500萬台裝置。使用XMPP傳遞新聞、通知和其他訊息。[7]
- Odnoklassniki ~4200萬用戶。 用戶之間的內部訊息傳遞通過XMPP客戶端提供社交網絡連接。
- 英雄聯盟 ~2700萬用戶,使用XMPP進行聊天
- 無冬online ~1600萬用戶,使用XMPP進行聊天
- 堡壘之夜 ~2.5億用戶,使用XMPP進行聊天
- 星戰前夜 ~90萬用戶,使用XMPP進行聊天
- Google ~15億用戶。使用XMPP傳遞推播通知。
- 蘋果公司 ~5億用戶。使用XMPP傳遞推播通知。
- 美國國家安全域 ~使用 XMPP 進行內部通訊。[8]
- 歐洲議會 ~歐洲議會安全域建議議員使用Cisco Jabber而不是Signal或WhatsApp。[9]
實現
XMPP客戶端軟件
XMPP協定是由大量的XMPP協定的客戶端,伺服器和程式庫。主要的文章包含了幾個XMPP協定清單客戶的多種平台。
XMPP伺服器端軟件
參見
- 即時通訊軟件比較
- 流文字定向訊息協定(STOMP),由Codehaus開發,基於文字的訊息的傳輸協定,使用類似JMS的`目的地`語義;
- 高級訊息隊列協定(AMQP),一種訊息導向中間件提供的開放的應用層協定;
- 訊息隊列遙測傳輸(MQTT),一種輕量級訂閱-發佈協定。
註釋
- ^ Jabber Inc. - About Us. [2009-09-14]. (原始內容存檔於2007-07-03).
- ^ Jabber Software Foundation Renamed to XMPP Standards Foundation (頁面存檔備份,存於互聯網檔案館) 1月16日2007年 - jabber.org (頁面存檔備份,存於互聯網檔案館)仍舊被維護
- ^ XEP-0025: Jabber HTTP Polling. [2009-09-08]. (原始內容存檔於2020-10-29).
- ^ XEP-0124: Bidirectional-streams Over Synchronous HTTP (BOSH). [2009-09-08]. (原始內容存檔於2021-02-13).
- ^ ejabberd Massive Scalability: 1 Node — 2+ Million Concurrent Users | ProcessOne Blog. [2018-06-22]. (原始內容存檔於2018-06-22).
- ^ Uses of XMPP. [2018-06-22]. (原始內容存檔於2018-06-22).
- ^ ejabberd & Nintendo Switch NPNS | ProcessOne Blog. [2019-06-05]. (原始內容存檔於2019-06-05).
- ^ АНБ использует протокол Jabber для чатов — «Хакер». [2018-06-24]. (原始內容存檔於2018-06-25).
- ^ EU-Parlament empfiehlt Jabber statt WhatsApp und prüft Signal | heise online. [2019-10-19]. (原始內容存檔於2019-10-19).