网站首页 > 精选教程 正文
基于websocket单台机器支持百万连接分布式聊天(IM)系统
本文将介绍如何实现一个基于websocket分布式聊天(IM)系统。
使用golang实现websocket通讯, 单机可以支持百万连接, 使用gin框架、nginx负载、可以水平部署、程序内部相互通讯、使用grpc通讯协议。
https://github.com/link1st/gowebsocket
- 克隆项目
git clone git@github.com:link1st/gowebsocket.git
# 或
git clone https://github.com/link1st/gowebsocket.git
- 修改项目配置
cd gowebsocket
cd config
mv app.yaml.example app.yaml
# 修改项目监听端口,redis连接等(默认127.0.0.1:3306)
vim app.yaml
# 返回项目目录,为以后启动做准备
cd ..
- 配置文件说明
app:
logFile: log/gin.log # 日志文件位置
httpPort: 8080 # http端口
webSocketPort: 8089 # webSocket端口
rpcPort: 9001 # 分布式部署程序内部通讯端口
httpUrl: 127.0.0.1:8080
webSocketUrl: 127.0.0.1:8089
redis:
addr: "localhost:6379"
password: ""
DB: 0
poolSize: 30
minIDleConns: 30
- 启动项目
go run main.go
- 进入IM聊天地址 http://127.0.0.1:8080/home/index
- 到这里,就可以体验到基于webSocket的IM系统
猜你喜欢
- 2024-10-19 nginx 游乐场 - 实时在线验证nginx配置
- 2024-10-19 Go微服务精讲:Go-Zero全流程实战即时通讯(超清)
- 2024-10-19 27 | API网关:系统的门面要如何做呢?
- 2024-10-19 分布式文件go-fastdfs初应用 分布式文件标准
- 2024-10-19 『GCTT 出品』无停机优雅重启 Go 程序
- 2024-10-19 Go语言上手很简单 go语言基础入门
- 2024-10-19 全球足迹:用GoAccess绘制访问地图
- 2024-10-19 nginx docker 容器如何访问宿主机的 golang 程序
- 2024-10-19 全流程开发 GO实战电商网站高并发秒杀系统
- 2024-10-19 Go语言设计模式-代理 go语言程序设计
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)