×

FishChat分布式可伸缩IM服务器

消耗积分:2 | 格式:zip | 大小:11.96 MB | 2022-05-27

分享资料个

授权协议 Apache
开发语言 Google Go
操作系统 跨平台
软件类型 开源软件

软件简介

FishChat(鱼传——鱼传尺素),是一款纯 golang 编写优秀的即时通讯软件(IM), 它集合了市面上已有产品的优点, 并具备 智能硬件网关管理(学习QQ物联思想, 构思中)。

FishChat Android 客户端见 https://github.com/oikomi/FishChatAndroid (紧张开发中)

系统架构

pYYBAGKCPOWAWw7oAAFXpjQX-p4210.png

关键服务器详解

gateway

gateway server主要是接受client请求,进行通用的功能设置,目前这块只做了分配msg_server的功能,后面可根据需要进行扩展

在gateway server的配置文件中最重要的是配置msg_server列表

"MsgServerList"      : [
        "192.168.159.169:19000",
        "192.168.159.169:19001"
    ],

 

msg_server

msg_server是消息的主体,维护着客户端连接和keeplive,同时要注意router、manager和monitor都订阅了msg_server的channel

    SYSCTRL_CLIENT_STATUS = "/sysctrl/client-status"
    SYSCTRL_TOPIC_STATUS  = "/sysctrl/topic-status"
    SYSCTRL_TOPIC_SYNC    = "/sysctrl/topic-sync"
    SYSCTRL_SEND          = "/sysctrl/send"
    SYSCTRL_MONITOR       = "/sysctrl/monitor"

这些channel保证了msg_server在事件触发时会广播通知后面的router、manager和monitor服务

 

router

router顾名思义是做了msg_server之间的消息转发

 

manager

manager主要是管理client信息存储、离线消息存储等等,通过它和redis联系

 

monitor

monitor主要是收集监控各服务器状态信息,目前monitor是可选项,可按需要启动它

部署

FishChatServer采用分布式可伸缩部署方式。如果没有多机条件,可以单机部署:

建议: 单机测试部署

  • gateway一台

  • msg_server两台

  • router一台

  • manager一台

  • monitor一台

./gateway

./msg_server -conf_file=msg_server.19001.json

./msg_server -conf_file=msg_server.19000.json

./router

./manager

./monitor

按上面的默认启动方式,查看系统的监听端口如下pYYBAGKCPOeAUmthAAAm2Jgoo0U298.png

当然你可以修改各文件夹下面的json配置文件修改配置参数

 

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !