项目简介
基于SignalR实现聊天通信,支持横向扩展,可支撑上万用户同时在线聊天
快速体验
http://server.tokengo.top:8888/ 可在这里快速体验使用,请注意目前只适配了PC端,请勿使用手机访问,可能出现样式不适应的情况,
当然如果你想要自己部署也可以,目前提供了docker compose镜像一键部署
下面是docker-compose
代码
services:
postgres:
image: postgres:15.3-alpine3.18
restart: always
container_name: postgres
ports:
- 5432:5432
networks:
- chat
environment:
POSTGRES_USER: token
POSTGRES_PASSWORD: dd666666
POSTGRES_DB: Chat
volumes:
- ./postgres_data:/var/lib/postgresql/data
redis:
image: redis:alpine3.16
restart: always
container_name: redis
ports:
- 6379:6379
networks:
- chat
command: redis-server --appendonly yes
volumes:
- ./redisdata:/data
nginx:
image: nginx:stable-alpine
restart: always
container_name: nginx
networks:
- chat
ports:
- 1080:80
volumes:
- ./nginx.conf:/etc/nginx/co服务器托管网nf.d/default.conf
chat-web:
build:
context: ./web
dockerfile: ./Dockerfile
container_name: chat-web
image: registry.cn-shenzhen.aliyuncs.com/gotrays/chat-web
restart: always
depends_on:
- redis
- postgres
networks:
- chat
chat-api:
build:
context: ./
dockerfile: ./src/Chat.Service/Dockerfile
container_name: chat-api
image: registry.cn-shenzhen.aliyuncs.com/gotrays/chat-api
restart: always
depends_on:
- redis
- postgres
networks:
- chat
networks:
chat:
driver: bridge
注,容器并不会一次性启动成功,可能由首次启动的时候postgres未初始化成功导致Api服务启动失败,可能需要重启服务
后端架构
后端技术栈采用
- .NET 7
- PostgreSQL (业务数据库)
- Redis(用于存放热点数据,和支持SignalR横向扩展)
- MasaFramework(后端应用框架)+DDD(领域驱动设计)+CQRS(读写分离)
前端架构
- React(Web版UI框架)
- Vite(打包运行)
- Semi(UI框架)
- Avalonia(客户端版UI框架)
Web界面预览,
并且输入框支持直接cv图片,当我们点击发送的时候会将图片和文字拆分发送。
目前支持Gitee直接登录或输入账号密码登录,(Github由于服务器无法访问到Api暂时无法使用)
后端项目结构
项目开源地址
gitee:https://gitee.com/hejiale010426/chat
github https://github.com/239573049/chat
技术交流群 :737776595
Chat后续计划
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
相关推荐: Ansible3:ansible.cfg配置说明
Ansible默认安装好后有一个配置文件/etc/ansible/ansible.cfg,该配置文件中定义了ansible的主机的默认配置部分,如默认是否需要输入密码、是否开启sudo认证、action_plugins插件的位置、hosts主机组的位置、是否…