開發(fā)IM(即時通訊)服務(wù)端

首先講講IM(即時通訊)技術(shù)可以用來做什么:

可以說幾乎所有高實時性的應(yīng)用場景都需要用到IM技術(shù)囱桨。

本篇將帶大家從零開始搭建一個輕量級的IM服務(wù)端,麻雀雖小嗅绰,五臟俱全舍肠,我們搭建的IM服務(wù)端實現(xiàn)以下功能:


一對一的文本消息、文件消息通信

每個消息有“已發(fā)送”/“已送達(dá)”/“已讀”回執(zhí)

存儲離線消息

支持用戶登錄窘面,好友關(guān)系等基本功能翠语。

能夠方便地水平擴(kuò)展

通過這個項目能學(xué)到什么?

這個項目涵蓋了很多后端必備知識:

rpc通信

數(shù)據(jù)庫

緩存

消息隊列

分布式民镜、高并發(fā)的架構(gòu)設(shè)計

docker部署

消息通信

文本消息

我們先從最簡單的特性開始實現(xiàn):一個普通消息的發(fā)送


我們現(xiàn)在有兩個用戶:Alice和Bob連接到了服務(wù)器啡专,當(dāng)Alice發(fā)送消息message(hello)給Bob,服務(wù)端接收到消息制圈,根據(jù)消息的destId進(jìn)行轉(zhuǎn)發(fā)们童,轉(zhuǎn)發(fā)給Bob。即時通訊開發(fā)咨詢小藍(lán)豆

發(fā)送回執(zhí)

那我們要怎么來實現(xiàn)回執(zhí)的發(fā)送呢鲸鹦?

我們定義一種回執(zhí)數(shù)據(jù)格式ACK慧库,MsgType有三種,分別是sent(已發(fā)送),delivered(已送達(dá)), read(已讀):

在服務(wù)器這里不區(qū)分ChatMsg和AckMsg馋嗜,處理過程都是一樣的:解析消息的destId并進(jìn)行轉(zhuǎn)發(fā)齐板。

水平擴(kuò)展

當(dāng)用戶量越來越大,必然需要增加服務(wù)器的數(shù)量葛菇,用戶的連接被分散在不同的機(jī)器上甘磨。此時,就需要存儲用戶連接在哪臺機(jī)器上眯停。

我們引入一個新的模塊來管理用戶的連接信息济舆。

這樣我們就能夠?qū)τ脩暨B接狀態(tài)進(jìn)行管理了,具體的實現(xiàn)應(yīng)考慮服務(wù)的用戶量莺债、期望性能等進(jìn)行實現(xiàn)滋觉。

此處我們使用redis來實現(xiàn)签夭,將userId和connectorId的關(guān)系以key-value的形式存儲。

消息轉(zhuǎn)發(fā)

除此之外椎侠,還需要一個模塊在不同的機(jī)器上轉(zhuǎn)發(fā)消息第租,

此時我們的服務(wù)被拆分成了connector和transfer兩個模塊,connector模塊用于維持用戶的長鏈接我纪,而transfer的作用是將消息在多個connector之間轉(zhuǎn)發(fā)慎宾。

現(xiàn)在Alice和Bob連接到了兩臺connector上,那么消息要如何傳遞呢宣羊?

1.Alice上線璧诵,連接到機(jī)器[1]上時

將Alice和它的連接存入內(nèi)存中。

調(diào)用user status的online方法記錄Alice上線仇冯。

2.Alice發(fā)送了一條消息給Bob

機(jī)器[1]收到消息后之宿,解析destId,在內(nèi)存中查找是否有Bob苛坚。

如果沒有比被,代表Bob未連接到這臺機(jī)器,則轉(zhuǎn)發(fā)給transfer泼舱。

3.transfer調(diào)用user status的getConnectorId(Bob)方法找到Bob所連接的connector等缀,返回機(jī)器[2],則轉(zhuǎn)發(fā)給機(jī)器[2]娇昙。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末尺迂,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子冒掌,更是在濱河造成了極大的恐慌噪裕,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件股毫,死亡現(xiàn)場離奇詭異膳音,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)铃诬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門祭陷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人趣席,你說我怎么就攤上這事兵志。” “怎么了宣肚?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵毒姨,是天一觀的道長。 經(jīng)常有香客問我钉寝,道長弧呐,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任嵌纲,我火速辦了婚禮俘枫,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘逮走。我一直安慰自己鸠蚪,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布师溅。 她就那樣靜靜地躺著茅信,像睡著了一般。 火紅的嫁衣襯著肌膚如雪墓臭。 梳的紋絲不亂的頭發(fā)上蘸鲸,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機(jī)與錄音窿锉,去河邊找鬼酌摇。 笑死,一個胖子當(dāng)著我的面吹牛嗡载,可吹牛的內(nèi)容都是我干的窑多。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼洼滚,長吁一口氣:“原來是場噩夢啊……” “哼埂息!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起遥巴,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤千康,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后挪哄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吧秕,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年迹炼,在試婚紗的時候發(fā)現(xiàn)自己被綠了砸彬。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡斯入,死狀恐怖砂碉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情刻两,我是刑警寧澤增蹭,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站磅摹,受9級特大地震影響滋迈,放射性物質(zhì)發(fā)生泄漏霎奢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一饼灿、第九天 我趴在偏房一處隱蔽的房頂上張望幕侠。 院中可真熱鬧,春花似錦碍彭、人聲如沸晤硕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽舞箍。三九已至,卻和暖如春皆疹,著一層夾襖步出監(jiān)牢的瞬間疏橄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工墙基, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留软族,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓残制,卻偏偏與公主長得像立砸,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子初茶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容