Skip to content

txchat/dtalk

Repository files navigation

即时通讯系统

注意: main分支在开发过程中可能处于不稳定甚至损坏的状态。

本仓库是即时通讯的服务端,使用im消息网关提供的特性,针对即时通讯场景实现消息可靠送达,离线推送,群用户管理等相关功能;网关服务的启动入口已经在仓库内打包。

dtalk-arch

开始

从源码编译

环境要求:

  1. Golang 1.17 or later, 参考golang官方安装文档
# 编译本机系统和指令集的可执行文件
$ make build

# 编译目标机器的可执行文件,例如
$ make build_linux_amd64

编译成功后目标执行文件在工程目录的target文件夹下。

运行服务命令:

# <serviceName>表示具体要运行的服务名称
$ ./target/<serviceName> -f ./target/<serviceName>.toml

docker容器中运行

环境要求:

  1. Golang 1.17 or later, 参考golang官方安装文档
  2. docker engine version 20.10.17 or later, 安装参考docker官方安装文档
# 初始化docker环境
$ make init-compose

# 打包镜像及运行容器
$ make docker-compose-up

# 查看容器是否运行成功
$ make docker-compose-ps

使用工具验证

使用im-util仓库下的pressure工具测试服务是否成功部署。

查看默认端口是否开放:

# 服务器ip或域名
$ telnet <ip>:8888

执行pressure命令行工具:

# <ip>为comet服务ip地址
$ ./pressure pre -s "<ip>:3102" -u 2 -t 5s

等待命令执行成功后会在可执行文件目录下生成pressure_output.txt文件,再执行:

$ ./pressure ana

# 控制台打印出如下内容表示发送的消息全都成功 failed count: 0
{"level":"info","time":"2022-07-26T11:10:27.879292+08:00","message":"message tranport success count: 10 -- failed count: 0"}

贡献

克隆代码到本地,在修改代码时请结合make fmt格式化,make linter做代码检查。

License

dtalk is under the MIT license. See the LICENSE file for details.