cp .env.example .env
vim .env
编辑.env
的配置为自己的
pnpm install # 安装环境变量
pnpm dev # 启动开发服务器
强烈建议使用 Docker
初始化第三方开发环境, 隔离性更加好 并且无需复杂的安装配置。
mongodb
docker run -d --name mongo -p 127.0.0.1:27017:27017 mongo:4
redis
docker run -d --name redis -p 127.0.0.1:6379:6379 redis
minio
docker run -d \
-p 127.0.0.1:19000:9000 \
-p 127.0.0.1:19001:9001 \
--name minio \
-e "MINIO_ROOT_USER=tailchat" \
-e "MINIO_ROOT_PASSWORD=com.msgbyte.tailchat" \
minio/minio server /data --console-address ":9001"
安装所有插件
pnpm plugin:install all
安装单个插件
pnpm plugin:install com.msgbyte.tasks
请确保已经安装了:
- docker
- docker-compose
在项目根目录下执行
docker-compose build # 需要编译
docker-compose up -d
docker exec -it <MONGO_DOCKER_NAME> mongodump -h 127.0.0.1 --port 27017 -d <MONGO_COLLECTION_NAME> -o /opt/backup/
docker exec -it <MONGO_DOCKER_NAME> tar -zcvf /tmp/mongodata.tar.gz /opt/backup/<MONGO_COLLECTION_NAME>
docker cp <MONGO_DOCKER_NAME>:/tmp/mongodata.tar.gz ${PWD}/
docker cp mongodata.tar.gz <MONGO_DOCKER_NAME>:/tmp/
docker exec -it <MONGO_DOCKER_NAME> tar -zxvf /tmp/mongodata.tar.gz
docker exec -it <MONGO_DOCKER_NAME> mongorestore -h 127.0.0.1 --port 27017 -d <MONGO_COLLECTION_NAME> /opt/backup/<MONGO_COLLECTION_NAME>
docker run -it --rm --volumes-from <DOCKER_CONTAINER_NAME> -v ${PWD}:/opt/backup --name export busybox sh
# 进入容器
tar -zcvf /opt/backup/data.tar <DATA_PATH>
exit
此处<DATA_PATH>, 如果是minio则为/data/
如果是mongo则为/data/db
docker run -it --rm --volumes-from <DOCKER_CONTAINER_NAME> -v ${PWD}:/opt/backup --name importer busybox sh
tar -zxvf /opt/backup/data.tar
exit
部署环境
hash: 4771a830b0787280d53935948c99c340c81de977
env: development
cpu: i7-8700K
memory: 32G
节点数: 1
测试终端: tailchat-cli
测试脚本: bench --time 60 --num 10000 "chat.message.sendMessage" '{"converseId": "61fa58845aff4f8a3e68ccf3", "groupId": "61fa58845aff4f8a3e68ccf4", "content": "123"}'
备注:
- 使用`Redis`作为消息中转中心, `Redis`部署在局域网的nas上
- 使用一个真实账户作为消息推送的接收方
Benchmark result:
3,845 requests in 1m, 0 error
Requests/sec: 64
Latency:
Avg: 15ms
Min: 9ms
Max: 91ms