Skip to content

haoxiuwang/FishChatServer2

 
 

Repository files navigation

FishChatServer2

Table of Contents

1说明

吸取了第一版的经验以及我们商业版的探索. 第二版我更多的思考在不要过多的实现轮子, 这个版本将很多业务无关的代码去掉, 并且尽量靠拢微服务. 部署方式可以支持:

  • 普通部署
  • 容器部署 (Kubernetes + Docker)

返回目录

2架构

返回目录

3协议

protocol目录下

  • external 是对外的协议,采用protobuf实现
  • rpc 是服务内部的调用,采用grpc

返回目录

4服务说明

进入server目录下

access
gateway
logic
manager
register

返回目录

5依赖

etcd
redis
mongodb
kafka
ElasticSearch(可选)

返回目录

6部署

6.1普通部署

为了方便, 我们在单机上进行部署

6.1.1依赖安装

安装完成之后创建两个topic:

p2p topic:
bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic logic_producer_p2p

group topic:
bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic logic_producer_group
  • redis安装 : 采用默认安装即可

  • mongodb安装 : 采用默认安装即可

  • etcd安装 : 需要3.0以上版本, 采用默认安装即可

6.1.2服务安装

进入server下面的各个目录 运行 go build, 然后启动服务即可(因为服务做了服务发现, 所以对启动顺序没有要求), 这里为了简单, 每个服务我们只启动一个, 当然启动任意个都是支持的.

  • gateway安装
➜  FishChatServer2 git:(master) ✗ cd server/gateway 
➜  gateway git:(master) ✗ go build
➜  gateway git:(master) ✗ ./gateway 
  • access安装
➜  FishChatServer2 git:(master) ✗ cd server/access 
➜  access git:(master) ✗ go build
➜  access git:(master) ✗ ./access 
  • logic安装
➜  FishChatServer2 git:(master) ✗ cd server/logic 
➜  logic git:(master) ✗ go build
➜  logic git:(master) ✗ ./logic 
  • register安装
➜  FishChatServer2 git:(master) ✗ cd server/register 
➜  register git:(master) ✗ go build
➜  register git:(master) ✗ ./register 
  • manager安装
➜  FishChatServer2 git:(master) ✗ cd server/manager 
➜  manager git:(master) ✗ go build
➜  manager git:(master) ✗ ./manager 

6.1.3job安装

  • msg_job安装
➜  FishChatServer2 git:(master) ✗ cd jobs/msg_job 
➜  msg_job git:(master) ✗ go build
➜  msg_job git:(master) ✗ ./msg_job 

6.2容器部署

部署完全采用Kubernetes + Docker

所以第一步需要搭建KubernetesDocker, 幸运的是现在网络上已经有大量的资料了, 这块我就不多写了.

返回目录

7测试

7.1点对点聊天测试

进入client/p2p目录, 用户可以启动两个以上的进程, 两两之间互相聊天

➜  FishChatServer2 git:(master) ✗ cd client/p2p 
➜  p2p git:(master) ✗ go build
➜  p2p git:(master) ✗ ./p2p 
输入我的id :321
输入对方的id :收到点对点消息: 返回码[0], 对方ID[321], 消息内容[hello]

7.2群聊测试

返回目录

8监控

返回目录

About

FishChatServer2 - QQ群274828795

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 97.5%
  • Protocol Buffer 2.5%