chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

go語言實現(xiàn)的簡單im即時通信系統(tǒng)解析

Linux愛好者 ? 來源:大嗚 ? 作者:大嗚 ? 2021-10-26 09:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

【導讀】本文介紹了一個 go 語言實現(xiàn)的簡單 im 即時通信系統(tǒng)。

簡介

純go實現(xiàn)的im即時通訊系統(tǒng),各層可單獨部署,之間通過rpc通訊,支持集群,github地址 https://github.com/Terry-Ye/im_api , 學習于goim, 總分三層,

comet(用戶連接層),可以直接部署多個節(jié)點,每個節(jié)點保證serverId 唯一,在配置文件comet.toml

logic(業(yè)務(wù)邏輯層),無狀態(tài),各層通過rpc通訊,容易擴展,支持http接口來接收消息

job(任務(wù)推送層)通過redsi 訂閱發(fā)布功能進行推送到comet層。

時序圖

以下Comet 層,Logic 層,Job層都可以靈活擴展機器

特性

分布式,可拓撲的架構(gòu)

支持單個,房間推送

心跳支持(gorilla/websocket內(nèi)置)

基于redis 做消息推送

輕量級

持續(xù)迭代。。.

部署

安裝

goget-ugithub.com/Terry-Ye/im
mv$GOPATH/src/github.com/Terry-Ye/im$GOPATH/src/im
cd$GOPATH/src/im
goget./...

golang.org 包拉不下來的情況,例

packagegolang.org/x/net/ipv4:unrecognizedimportpath"golang.org/x/net/ipv4"(httpsfetch:Gethttps://golang.org/x/net/ipv4?go-get=1:dialtcp216.239.37.1i/otimeout)

從github 拉下來,再移動位置

gitclonehttps://github.com/golang/net.git
mkdir-pgolang.org/x/

mvnet$GOPATH/src/golang.org/x/
  1. 部署im

安裝comet、logic、job模塊

cd$GOPATH/src/im/comet
goinstall
cd../logic/
goinstall
cd../job
goinstall

nohup$GOPATH/bin/logic-d$GOPATH/src/im/logic/2>&1>/data/log/im/logic.log&

nohup$GOPATH/bin/comet-d$GOPATH/src/im/comet/2>&1>/data/log/im/comet.log&

nohup$GOPATH/bin/job-d$GOPATH/src/im/job/2>&1>/data/log/im/job.log&
  1. im_api 是im系統(tǒng)中使用的接口,需要像demo那樣整體跑起來需要完整的部署

部署注意事項

  1. 部署服務(wù)器注意防火墻是否開放對應(yīng)的端口(本地不需要,具體需要的端口在各層的配置文件)

demo

聊天室:http://www.texixi.com:1999/

使用的包

  • log: github.com/sirupsen/logrus
  • rpc: github.com/smallnest/rpcx
  • websocket: github.com/gorilla/websocket
  • 配置文件:github.com/spf13/viper

后續(xù)計劃

  1. 在線列表
  2. 支持wss
  3. 聊天機器人

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 通信系統(tǒng)
    +關(guān)注

    關(guān)注

    6

    文章

    1249

    瀏覽量

    55004
  • 聊天機器人
    +關(guān)注

    關(guān)注

    0

    文章

    348

    瀏覽量

    13049
  • go語言
    +關(guān)注

    關(guān)注

    1

    文章

    159

    瀏覽量

    9648

原文標題:支持分布式的 go 實現(xiàn)即時通訊系統(tǒng)

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    KIT_XMC14_2GO開發(fā)板:功能特性與硬件解析

    KIT_XMC14_2GO開發(fā)板:功能特性與硬件解析 在電子開發(fā)領(lǐng)域,一款性能出色且功能豐富的開發(fā)板對于工程師來說至關(guān)重要。今天,我們就來詳細探討一下KIT_XMC14_2GO開發(fā)板,它配備了英飛凌
    的頭像 發(fā)表于 12-19 10:20 ?101次閱讀

    socket是什么

    特定的IP地址和端口上等待客戶端連接,客戶端則通過Socket連接到服務(wù)器程序并進行通信。通過Socket技術(shù),可以實現(xiàn)不同操作系統(tǒng)和編程語言之間的
    發(fā)表于 12-03 08:27

    米爾 SECC 方案:國標充電樁多協(xié)議兼容的通信基礎(chǔ)解析

    槍狀態(tài)、通信階段- ADC 狀態(tài)采集:檢測電氣狀態(tài)是否達標- 多接口通信模塊:實現(xiàn)車輛、樁控系統(tǒng)與后臺之間的聯(lián)動- 基礎(chǔ)安全保護:確保通信
    發(fā)表于 11-20 17:46

    常用Web 實時通信技術(shù):原理+選型,一篇通關(guān)

    用的實時通信技術(shù),從概念、原理特點、適用場景、對比選型進行詳細解析。 一、WebSocket 1.1、核心概念 WebSocket 是 Web 端實時通信的 “基礎(chǔ)設(shè)施”,通過 全雙工長連接 和 輕量幀傳輸 ,解決了 HTTP
    的頭像 發(fā)表于 10-27 17:19 ?537次閱讀
    常用Web 實時<b class='flag-5'>通信</b>技術(shù):原理+選型,一篇通關(guān)

    協(xié)議解析網(wǎng)關(guān)是什么?有什么功能?

    、OPCUA、HTTP等),并將其轉(zhuǎn)換為目標系統(tǒng)或設(shè)備可識別的協(xié)議格式,從而實現(xiàn)跨協(xié)議的通信與數(shù)據(jù)交互。 簡單來說,協(xié)議解析網(wǎng)關(guān)就像“翻譯官
    的頭像 發(fā)表于 08-13 14:04 ?641次閱讀
    協(xié)議<b class='flag-5'>解析</b>網(wǎng)關(guān)是什么?有什么功能?

    即時通話軟件音頻傳輸質(zhì)量測試方案介紹

    本套測試方案的核心目的是通過POLQA(Perceptual Objective Listening Quality Assessment)主觀音質(zhì)評價測試來反映即時通話軟件在使用過程中的音頻
    的頭像 發(fā)表于 08-10 15:21 ?3449次閱讀
    <b class='flag-5'>即時通</b>話軟件音頻傳輸質(zhì)量測試方案介紹

    通用衛(wèi)星通信模擬仿真系統(tǒng)全面解析

    通用衛(wèi)星通信模擬仿真系統(tǒng)全面解析
    的頭像 發(fā)表于 07-28 09:26 ?520次閱讀
    通用衛(wèi)星<b class='flag-5'>通信</b>模擬仿真<b class='flag-5'>系統(tǒng)</b>全面<b class='flag-5'>解析</b>

    基于瑞芯微RK3562 的四核 AR M Cortex-A53 + 單核 ARM Cortex-M0工業(yè)評估板——MQTT通信方案

    MQTT作為一種低開銷,低帶寬占用的即時通訊協(xié)議,可以極少的代碼和帶寬為聯(lián)網(wǎng)設(shè)備提供實時可靠的消息服務(wù),適用于硬件資源有限的設(shè)備及帶寬有限的網(wǎng)絡(luò)環(huán)境。我司提供的評估板文件系統(tǒng)已支持Mosquitto工具,本文mqtt_client案例采用Mosquitto工具演示MQTT
    的頭像 發(fā)表于 06-05 15:00 ?1773次閱讀
    基于瑞芯微RK3562 的四核 AR M Cortex-A53 + 單核 ARM Cortex-M0工業(yè)評估板——MQTT<b class='flag-5'>通信</b>方案

    鴻蒙5開發(fā)寶藏案例分享---一多開發(fā)實例(即時通訊)

    們準備好了超多實用開發(fā)案例!尤其是那個讓無數(shù)人頭疼的\"一次開發(fā)多端部署\",官方竟然悄悄塞了這么多實戰(zhàn)技巧!(拍大腿) ?先上硬核案例:即時通訊應(yīng)用的多端魔法? 官方這個即時通
    發(fā)表于 06-03 16:01

    單片機C語言實例(350+例)

    350+單片機C語言實例! 純分享帖,需要者可點擊附件免費獲取完整資料~~~【免責聲明】本文系網(wǎng)絡(luò)轉(zhuǎn)載,版權(quán)歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權(quán)問題,請第一時間告知,刪除內(nèi)容!
    發(fā)表于 05-22 21:47

    基于Verilog語言實現(xiàn)CRC校驗

    CRC即循環(huán)冗余校驗碼:是數(shù)據(jù)通信領(lǐng)域中最常用的一種查錯校驗碼,其特征是信息字段和校驗字段的長度可以任意選定。循環(huán)冗余檢查(CRC)是一種數(shù)據(jù)傳輸檢錯功能,對數(shù)據(jù)進行多項式計算,并將得到的結(jié)果附在幀的后面,接收設(shè)備也執(zhí)行類似的算法,以保證數(shù)據(jù)傳輸?shù)恼_性和完整性。
    的頭像 發(fā)表于 03-24 10:36 ?2230次閱讀
    基于Verilog<b class='flag-5'>語言實現(xiàn)</b>CRC校驗

    ?VLM(視覺語言模型)?詳細解析

    的詳細解析: 1. 核心組成與工作原理 視覺編碼器 :提取圖像特征,常用CNN(如ResNet)或視覺Transformer(ViT)。 語言模型 :處理文本輸入/輸出,如GPT、BERT等,部分模型
    的頭像 發(fā)表于 03-17 15:32 ?7779次閱讀
    ?VLM(視覺<b class='flag-5'>語言</b>模型)?詳細<b class='flag-5'>解析</b>

    PID控制算法的C語言實現(xiàn):PID算法原理

    在工業(yè)應(yīng)用中 PID 及其衍生算法是應(yīng)用最廣泛的算法之一,是當之無愧的萬能算法,如果能夠熟練掌握 PID 算法的設(shè)計與實現(xiàn)過程,對于一般的研發(fā)人員來講,應(yīng)該是足夠應(yīng)對一般研發(fā)問題了,而難能可貴
    發(fā)表于 02-26 15:24

    華為云 Flexus X 實例云服務(wù)器部署即時通IM 項目

    @TOC ? 寫在前面 手里拿到了一臺 華為云 Flexus X 實例 的云服務(wù)器,部署部署項目試試看看性能怎么樣。正當華為云 828 上云活動,可領(lǐng) 8280 元的券,活動地址在這里:點我查看 ? 讓我們來看看干點什么呢?部署個實用的應(yīng)用吧~ Flexus X 實例云服務(wù)器 介紹 首先,flexus 系列的產(chǎn)品不止有云服務(wù)器,還有如下一些產(chǎn)品: 1.?Flexus L 實例的云服務(wù)器 2.?Flexus X 實例的云服務(wù)器 3.?Flexus 云數(shù)據(jù)庫 RDS 4.?Flexus 云容器實例 5.?Flexus 數(shù)字人 6.?Flexus 企業(yè)搜索服務(wù) 7.?Fle
    的頭像 發(fā)表于 02-07 10:15 ?725次閱讀
    華為云 Flexus X 實例云服務(wù)器部署<b class='flag-5'>即時通</b>訊 <b class='flag-5'>IM</b> 項目

    基于FPGA實現(xiàn)圖像直方圖設(shè)計

    簡單,單采用FPGA來實現(xiàn)直方圖的統(tǒng)計就稍顯麻煩。若使用Xilinx和Altera的FPGA芯片,可以使用HLS來進行圖像的加速處理。但這暫時不是我的重點。 用C語言實現(xiàn)直方圖統(tǒng)計:unsigned
    的頭像 發(fā)表于 12-24 10:24 ?1235次閱讀
    基于FPGA<b class='flag-5'>實現(xiàn)</b>圖像直方圖設(shè)計