Docker部署gochat聊天系统

MacOS Docker 安装 

1、使用 Homebrew 安装

macOS 我们可以使用 Homebrew 来安装 Docker。

Homebrew 的 Cask 已经支持 Docker for Mac,因此可以很方便的使用 Homebrew Cask 来进行安装:

$ brew install --cask --appdir=/Applications docker

2、手动下载安装

1、如果需要手动下载,请点击以下链接下载 Stable(https://download.docker.com/mac/stable/Docker.dmg) 或 Edge (https://download.docker.com/mac/edge/Docker.dmg)版本的 Docker for Mac。

2、如同 macOS 其它软件一样,安装也非常简单,双击下载的 .dmg 文件,然后将鲸鱼图标拖拽到 Application 文件夹即可。

3、启动终端后,通过命令可以检查安装后的 Docker 版本。

    $ docker --version

4、对于使用 macOS 的用户,在任务栏点击 Docker Desktop 应用图标 -> Perferences,在左侧导航菜单选择

DockerEngine,在右侧像下边一样编辑 json 文件。修改完成之后,点击 Apply & Restart 按钮,Docker 就会重启并应

用配置的镜像地址了。

{

  "registry-mirrors": [

    "https://hub-mirror.c.163.com",

    "https://mirror.baidubce.com"

  ]

}

5、之后我们可以通过 docker info 来查看是否配置成功。

    # docker info

至此,docker已经安装结束


使用docker一键启动gochat

执行docker相关步骤的时候,会到hub.docker.com拉取相关镜像,可能需要翻墙,具体看你的网络。

1、你可以使用我推到docker hub上的镜像:

    默认镜像中已经创建了几个测试用户:

    用户名             密码

    demo             111111

    test                111111

    admin            111111

    第一步:docker pull lockgit/gochat:latest

    第二步:git clone git@github.com:LockGit/gochat.git

    第三步:cd gochat && sh run.sh dev (该步骤需要一定时间编译各个模块,耐心等待即可,部分系统可能没有sh,如果

执行报错,把sh run.sh dev改为./run.sh dev执行)

    第四步:访问 http://127.0.0.1:8080 开启聊天室

2、如果你想自己构建一个镜像,那么只需要build docker文件下的Dockerfile

    docker build -f docker/Dockerfile . -t lockgit/gochat

    上面build过程可能需要翻墙且需要一定时间,完成后执行:

    第一步:git clone git@github.com:LockGit/gochat.git

    第二步:cd gochat && sh run.sh dev (该步骤需要一定时间编译各个模块,耐心等待即可,部分系统可能没有sh,如果

执行报错,把sh run.sh dev改为./run.sh dev执行)

    第三步:访问 http://127.0.0.1:8080 开启聊天室

3、如果你要部署在个人vps上,记得修改site/js/common.js中socketUrl与apiUrl的地址为你的vps的ip地址,

并确保vps上没有针对相关端口的防火墙限制。


gochat目录结构

├── api # api接口层,提供rest api服务,主要rpc call logic层服务,可水平扩展

├── architecture       # 架构图资源图片文件夹

├── bin                      # golang编译后的二进制文件,不参与提交至git仓库

├── config                 # 配置文件

├── connect              # 链接层,该层用于handler住大量用户长连接,实时消息推送,除此之外,主要rpc call logic层服务,可水平扩展

├── db                       # 数据库链接初始化,内部gochat.sqlite3为方便演示时使用的sqlite数据库,实际场景可替换为其他关系型数据库

├── docker                # 用于快速构建docker环境

├── go.mod              # go包管理mod文件

├── go.sum              # go包管理sum文件

├── logic                # 逻辑层,该层主要接收connect层与api层的rpc请求。如果是消息,会push到队列,最终被task层消费,可水平扩展

├── main.go              # gochat程序唯一入口文件

├── proto                # golang rpc proto 文件

├── readme.md            # 中文说明文档

├── readme.en.md        # 英文说明文档

├── reload.sh            # 编译gochat并执行supervisorctl restart重启相关进程

├── run.sh              # 快速构建一个docker容器,启动demo

├── site                # 站点层,该层为纯静态页面,会http请求api层,可水平扩展

├── task                # 任务层,该层消费队列中的数据,并且rpc call connect层执行消息的发送,可水平扩展

├── tools                # 工具方法

└── vendor              # vendor包


Websocket && Tcp消息互通

    1、tcp消息投递与接收测试代码在本项目pkg/stickpackage目录中的:stickpackage_test.go文件中的Test_TcpClient方法

    其中stickpackage.go文件主要为实现tcp拆包解包时用到,可以追踪下其中Pack与Unpack方法的调用地方。

    主要原因是tcp是基于第4层的流式协议而非应用层协议,所以才有了这个过程。

    如果是android,ios客户端来链接,那么对应的就是需要用熟悉的语言来实现这个tcp拆包解包的过程,例子中的代码是golang实现的demo。

    go test -v -count=1 *.go -test.run Test_TcpClient

    2、如果是测试tcp消息投递:

    只需要修改这个方法中@todo部分的内容为你测试时正确的内容即可,测试tcp端口使用7001,7002,如果是在个人vps上,注意配置防火墙放行相关端口。

    authToken为进行tcp链接时的认证token,这个token是用户标识,在web上登录后的api返回中可以看到json返回,也可以直接在redis中去查到某一个用户的token。

    服务端接收到这个authToken时会把对应用户tcp链接会话加入到相应房间的会话双向链表中。

    3、加入支持tcp后,如果一个房间中既有通过websocket进行链接的用户,又有通过tcp进行链接的用户,那么消息投递大致流程:

        1,首先用户登录,携带token,房间号去连接websocket,tcp服务端,在链接层建立长链接会话,

            比如用户A在房间1,通过websocket链接,用户B也在房间1,通过tcp链接。

        2,用户向房间内发送消息,目前是直接把消息通过http投到相应消息队列中,

            这个地方,其实也可以通过websocket,tcp来发,不过最终消息都是要进队列的。

        3,task层消费队列中的消息,rpc广播到websocket链接层和tcp链接层的相应房间中,

            链接层获得消息后,把消息投递到对应的远端用户(相当于遍历房间中维护的用户链接会话双向链表)




部署完成访问界面
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容