91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

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

馬哥Linux運維 ? 來源:Go開發(fā)大全 ? 作者:Go開發(fā)大全 ? 2021-10-20 16:02 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

簡介

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

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

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

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

系統(tǒng)架構(gòu)圖

時序圖

以下Comet 層,Logic 層,Job層都可以靈活擴(kuò)展機器

特性

分布式,可拓?fù)涞募軜?gòu)

支持單個,房間推送

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

基于redis 做消息推送

輕量級

持續(xù)迭代。。.

部署

  1. 安裝
    
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. 聊天機器人

原文來自:www.ancii.com/awugjp68e/

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

    關(guān)注

    6

    文章

    1263

    瀏覽量

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

    關(guān)注

    0

    文章

    348

    瀏覽量

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

    關(guān)注

    1

    文章

    159

    瀏覽量

    9778

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

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

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

    無線生活,“藍(lán)牙”相連——探索藍(lán)牙技術(shù)的智能連接世界

    無線個域網(wǎng)的主流技術(shù)之一。二、五大核心特點1. 短距高效,即連即用藍(lán)牙設(shè)備可自動搜索并快速建立連接,無需復(fù)雜配置,實現(xiàn)設(shè)備間的即時通信與數(shù)據(jù)交換。2. 低功耗設(shè)計,持久續(xù)航藍(lán)牙低功耗模式適用于穿戴設(shè)備
    發(fā)表于 02-11 09:27

    連接數(shù)字的即時紐帶

    在數(shù)字時代,信息傳遞的速度決定著我們與世界互動的效率。實時通信(Real-TimeCommunication,RTC)技術(shù)正是這一需求的產(chǎn)物,它讓數(shù)據(jù)跨越物理距離,實現(xiàn)近乎瞬時的交換。與傳統(tǒng)
    的頭像 發(fā)表于 01-30 08:40 ?159次閱讀
    連接數(shù)字的<b class='flag-5'>即時</b>紐帶

    講解C語言代碼的實現(xiàn)過程

    重點講解C語言代碼的實現(xiàn)過程,算法的C語言實現(xiàn)過程具有一般性,通過PID算法的C語言實現(xiàn),可以以此類推,設(shè)計其它算法的C語言實現(xiàn)。 第一步:
    發(fā)表于 01-21 07:58

    C語言實現(xiàn)PID算法介紹

    是對目標(biāo)值和實際值誤差進(jìn)行比例、積分、微分運算后的結(jié)果用來作用在輸出上。 比例 (P) 比例控制是最簡單的一種控制方式,成比例的反應(yīng)控制系統(tǒng)中輸入與輸出的偏差信號,只要偏差一旦產(chǎn)生,就立即產(chǎn)生控制的作用
    發(fā)表于 01-16 07:24

    無線生活,“藍(lán)牙”相連——探索藍(lán)牙技術(shù)的智能連接世界

    無線個域網(wǎng)的主流技術(shù)之一。二、五大核心特點1. 短距高效,即連即用藍(lán)牙設(shè)備可自動搜索并快速建立連接,無需復(fù)雜配置,實現(xiàn)設(shè)備間的即時通信與數(shù)據(jù)交換。2. 低功耗設(shè)計,持久續(xù)航藍(lán)牙低功耗模式適用于穿戴設(shè)備
    發(fā)表于 01-14 09:23

    socket是什么

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

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

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

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

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

    海底光纜系統(tǒng)怎么組成

    在數(shù)字浪潮席卷全球的當(dāng)下,短視頻的沉浸式體驗、跨國即時通訊的暢所欲言以及全天候全球資訊的實時推送,早已成為我們生活的日常。
    的頭像 發(fā)表于 07-21 14:45 ?1081次閱讀

    智己IM5和IM6登陸英國市場

    近日,智己汽車全球化戰(zhàn)略迎來里程碑時刻。旗下明星車型——智己L6海外版IM5與智己LS6海外版IM6,盛大亮相全球頂級汽車盛會古德伍德速度節(jié)(Goodwood Festival of Speed
    的頭像 發(fā)表于 07-15 13:50 ?783次閱讀

    基于瑞芯微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 ?1906次閱讀
    基于瑞芯微RK3562 的四核 AR M Cortex-A53 + 單核 ARM Cortex-M0工業(yè)評估板——MQTT<b class='flag-5'>通信</b>方案

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

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

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

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

    從 Java 到 Go:面向?qū)ο蟮木奕伺c云原生的輕騎兵

    Go 語言在 2009 年被 Google 推出,在創(chuàng)建之初便明確提出了“少即是多(Less is more)”的設(shè)計原則,強調(diào)“以工程效率為核心,用極簡規(guī)則解決復(fù)雜問題”。它與 Java 語言生態(tài)
    的頭像 發(fā)表于 04-25 11:13 ?643次閱讀

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

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