Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/crossoverJie/cim
📲cim(cross IM) 适用于开发者的分布式即时通讯系统
https://github.com/crossoverJie/cim
heartbeat im netty tcp
Last synced: 3 months ago
JSON representation
📲cim(cross IM) 适用于开发者的分布式即时通讯系统
- Host: GitHub
- URL: https://github.com/crossoverJie/cim
- Owner: crossoverJie
- License: mit
- Created: 2018-05-20T15:55:56.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-21T02:04:25.000Z (4 months ago)
- Last Synced: 2024-11-04T11:03:12.264Z (4 months ago)
- Topics: heartbeat, im, netty, tcp
- Language: Java
- Homepage: https://crossoverjie.top/categories/Netty/
- Size: 33.3 MB
- Stars: 9,290
- Watchers: 393
- Forks: 2,846
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list - cim - 适用于开发者的分布式即时通讯系统 (Web Development / C++/C Toolkit)
- my-awesome - crossoverJie/cim - 11 star:9.4k fork:2.9k 📲cim(cross IM) 适用于开发者的分布式即时通讯系统 (Java)
README
![]()
[data:image/s3,"s3://crabby-images/2ee2d/2ee2dd7990adcbfcf135af2ef16fa7a091b23f91" alt="codecov"](https://codecov.io/gh/crossoverJie/cim)
[data:image/s3,"s3://crabby-images/a2f39/a2f3988e7926a1567cd52346da744c59aac1b120" alt="Build Status"](https://github.com/crossoverJie/cim)
[data:image/s3,"s3://crabby-images/b6e23/b6e2350d0472e17c629fff22383594789f9ff90d" alt=""](https://juejin.im/post/5c2bffdc51882509181395d7)📘[介绍](#介绍) |📽[视频演示](#视频演示) | 🏖[TODO LIST](#todo-list) | 🌈[系统架构](#系统架构) |💡[流程图](#流程图)|🌁[快速启动](#快速启动)|👨🏻✈️[内置命令](#客户端内置命令)|🎤[通信](#群聊私聊)|❓[QA](https://github.com/crossoverJie/cim/blob/master/doc/QA.md)|💌[联系作者](#联系作者)
# V2.0
- [x] Upgrade to JDK17 & springboot3.0
- [x] Client SDK
- [ ] Client use [picocli](https://picocli.info/) instead of springboot.
- [x] Support integration testing.
- [ ] Integrate OpenTelemetry .
- [ ] Support single node startup(Contains no components).
- [ ] Third-party components support replacement(Redis/Zookeeper, etc.).
- [ ] Support web client(websocket).
- [ ] Support docker container.
- [ ] Support kubernetes operation.
- [ ] Supports binary client(build with golang).## Introduction
`CIM(CROSS-IM)` is an `IM (instant messaging)` system for developers; it also provides some components to help developers build their own scalable `IM`.
Using `CIM`, you can achieve the following requirements:
- `IM` instant messaging system.
- Message push middleware for `APP`.
- Message middleware for `IOT` massive connection scenarios.> If you have any questions during use or development, you can [contact me](#联系作者).
## 视频演示
> 点击下方链接可以查看视频版 Demo。
| YouTube | Bilibili|
| :------:| :------: |
| [群聊](https://youtu.be/_9a4lIkQ5_o) [私聊](https://youtu.be/kfEfQFPLBTQ) | [群聊](https://www.bilibili.com/video/av39405501) [私聊](https://www.bilibili.com/video/av39405821) |
||
data:image/s3,"s3://crabby-images/d7a05/d7a050890d278a3c792e4d59e52037a24c96583f" alt="demo.gif"
## TODO LIST
* [x] [群聊](#群聊)
* [x] [私聊](#私聊)
* [x] [内置命令](#客户端内置命令)
* [x] [聊天记录查询](#聊天记录查询)。
* [x] [一键开启价值 2 亿的 `AI` 模式](#ai-模式)
* [x] 使用 `Google Protocol Buffer` 高效编解码
* [x] 根据实际情况灵活的水平扩容、缩容
* [x] 服务端自动剔除离线客户端
* [x] 客户端自动重连
* [x] [延时消息](#延时消息)
* [x] SDK 开发包
* [ ] 分组群聊
* [ ] 离线消息
* [ ] 消息加密## Architecture
data:image/s3,"s3://crabby-images/1b1ce/1b1ce0ae468ae4f69733b3e0fb7c5f6ad492b7b3" alt=""
- Each component in `CIM` is built using `SpringBoot`
- Client build with [cim-client-sdk](https://github.com/crossoverJie/cim/tree/master/cim-client-sdk)
- Use `Netty` to build the underlying communication.
- `MetaStore` is used for registration and discovery of `IM-server` services.### cim-server
IM server is used to receive client connections, message forwarding, message push, etc.
Support cluster deployment.### cim-route
Route server; used to process message routing, message forwarding, user login, user offline, and some operation tools (get the number of online users, etc.).
### cim-client
IM client terminal, a command can be started and initiated to communicate with others (group chat, private chat).## Flow Chart
data:image/s3,"s3://crabby-images/c78d6/c78d61a57db2a7dc333c960e0bb92dc57dfbfb5c" alt=""
- Server register to `MetaStore`
- Route subscribe `MetaStore`
- Client login to Route
- Route get Server info from `MetaStore`
- Client open connection to Server
- Client1 send message to Route
- Route select Server and forward message to Server
- Server push message to Client2## 快速启动
首先需要安装 `Zookeeper、Redis` 并保证网络通畅。
```shell
docker run --rm --name zookeeper -d -p 2181:2181 zookeeper:3.9.2
docker run --rm --name redis -d -p 6379:6379 redis:7.4.0
``````shell
git clone https://github.com/crossoverJie/cim.git
cd cim
mvn clean package -DskipTests=true
cd cim-server && cim-client && cim-forward-route
mvn clean package spring-boot:repackage -DskipTests=true
```### 部署 IM-server(cim-server)
```shell
cp /cim/cim-server/target/cim-server-1.0.0-SNAPSHOT.jar /xx/work/server0/
cd /xx/work/server0/
nohup java -jar /root/work/server0/cim-server-1.0.0-SNAPSHOT.jar --cim.server.port=9000 --app.zk.addr=zk地址 > /root/work/server0/log.file 2>&1 &
```> cim-server 集群部署同理,只要保证 Zookeeper 地址相同即可。
### 部署路由服务器(cim-forward-route)
```shell
cp /cim/cim-server/cim-forward-route/target/cim-forward-route-1.0.0-SNAPSHOT.jar /xx/work/route0/
cd /xx/work/route0/
nohup java -jar /root/work/route0/cim-forward-route-1.0.0-SNAPSHOT.jar --app.zk.addr=zk地址 --spring.redis.host=redis地址 --spring.redis.port=6379 > /root/work/route/log.file 2>&1 &
```> cim-forward-route 本身就是无状态,可以部署多台;使用 Nginx 代理即可。
### 启动客户端
```shell
cp /cim/cim-client/target/cim-client-1.0.0-SNAPSHOT.jar /xx/work/route0/
cd /xx/work/route0/
java -jar cim-client-1.0.0-SNAPSHOT.jar --server.port=8084 --cim.user.id=唯一客户端ID --cim.user.userName=用户名 --cim.route.url=http://路由服务器:8083/
```data:image/s3,"s3://crabby-images/0caa7/0caa785982243f04e7a227aad4716123998a4d7e" alt=""
data:image/s3,"s3://crabby-images/85c1a/85c1af36759264e6a1652188644c0bcfa415d88a" alt=""如上图,启动两个客户端可以互相通信即可。
### 本地启动客户端
#### 注册账号
```shell
curl -X POST --header 'Content-Type: application/json' --header 'Accept: application/json' -d '{
"reqNo": "1234567890",
"timeStamp": 0,
"userName": "zhangsan"
}' 'http://路由服务器:8083/registerAccount'
```从返回结果中获取 `userId`
```json
{
"code":"9000",
"message":"成功",
"reqNo":null,
"dataBody":{
"userId":1547028929407,
"userName":"test"
}
}
```#### 启动本地客户端
```shell
# 启动本地客户端
cp /cim/cim-client/target/cim-client-1.0.0-SNAPSHOT.jar /xx/work/route0/
cd /xx/work/route0/
java -jar cim-client-1.0.0-SNAPSHOT.jar --server.port=8084 --cim.user.id=上方返回的userId --cim.user.userName=用户名 --cim.route.url=http://路由服务器:8083/
```## 客户端内置命令
| 命令 | 描述|
| ------ | ------ |
| `:q!` | 退出客户端|
| `:olu` | 获取所有在线用户信息 |
| `:all` | 获取所有命令 |
| `:q [option]` | 【:q 关键字】查询聊天记录 |
| `:ai` | 开启 AI 模式 |
| `:qai` | 关闭 AI 模式 |
| `:pu` | 模糊匹配用户 |
| `:info` | 获取客户端信息 |
| `:emoji [option]` | 查询表情包 [option:页码] |
| `:delay [msg] [delayTime]` | 发送延时消息 |
| `:` | 更多命令正在开发中。。 |data:image/s3,"s3://crabby-images/882e9/882e9ac0ceed987a698f20197f0b41b6d11f28d0" alt=""
### 聊天记录查询
data:image/s3,"s3://crabby-images/836b7/836b771ae72bbf7af71ca5f12516c201946bfe8d" alt=""
使用命令 `:q 关键字` 即可查询与个人相关的聊天记录。
> 客户端聊天记录默认存放在 `/opt/logs/cim/`,所以需要这个目录的写入权限。也可在启动命令中加入 `--cim.msg.logger.path = /自定义` 参数自定义目录。
### AI 模式
data:image/s3,"s3://crabby-images/48aee/48aee16058136001bbfd4c7646d146bd3c2eab49" alt=""
使用命令 `:ai` 开启 AI 模式,之后所有的消息都会由 `AI` 响应。
`:qai` 退出 AI 模式。
### 前缀匹配用户名
data:image/s3,"s3://crabby-images/85061/85061fd853927b9ecd5260a1990a067fc80fb85f" alt=""
使用命令 `:qu prefix` 可以按照前缀的方式搜索用户信息。
> 该功能主要用于在移动端中的输入框中搜索用户。
### 群聊/私聊
#### 群聊
data:image/s3,"s3://crabby-images/810a6/810a66f76a073d2fb4f894b7e1d0f67a31e1dea6" alt=""
data:image/s3,"s3://crabby-images/50198/5019844d85728e30f601554cac27bb923f85d0a1" alt=""
data:image/s3,"s3://crabby-images/b7c2c/b7c2c4c05135acb2e31461ed9e17c0b06567f6a1" alt=""群聊只需要在控制台里输入消息回车后即可发送,同时所有在线客户端都可收到消息。
#### 私聊
私聊首先需要知道对方的 `userID` 才能进行。
输入命令 `:olu` 可列出所有在线用户。
data:image/s3,"s3://crabby-images/c1584/c1584b1e98ceb024c3d0a7b92a820e85a466bafc" alt=""
接着使用 `userId;;消息内容` 的格式即可发送私聊消息。
data:image/s3,"s3://crabby-images/6c682/6c682faf3f1d603ee8923f91f71afc771b135671" alt=""
data:image/s3,"s3://crabby-images/80706/8070635bc98454395bbd92632b1b153386034ba6" alt=""
data:image/s3,"s3://crabby-images/5bfc1/5bfc19b3605b09548782b9e553698e6afd464b62" alt=""
data:image/s3,"s3://crabby-images/56153/56153bef5251b878e6692c8ff6e2845c26b55eff" alt=""同时另一个账号收不到消息。
data:image/s3,"s3://crabby-images/9d28e/9d28e219f988dd0648e75883f572687fa149d86d" alt=""### emoji 表情支持
使用命令 `:emoji 1` 查询出所有表情列表,使用表情别名即可发送表情。
data:image/s3,"s3://crabby-images/b903d/b903da980b5164a90c89c5aa63b603d02ab8e31d" alt=""
data:image/s3,"s3://crabby-images/31940/3194012460e02bb7911031e4e0e0919cec9cd70a" alt=""
### 延时消息发送 10s 的延时消息:
```shell
:delay delayMsg 10
```data:image/s3,"s3://crabby-images/f0612/f0612d1ddaf9543437c5d40579faa77d575d8739" alt=""
## 联系作者
最近开通了知识星球,感谢大家对 CIM 的支持,为大家提供 100 份 10 元优惠券,也就是 69-10=59 元,具体福利大家可以扫码参考再决定是否加入。
> PS: 后续会在星球开始 V2.0 版本的重构,感兴趣的可以加入星球当面催更(当然代码依然会开源)。
- [[email protected]](mailto:[email protected])
- 微信公众号data:image/s3,"s3://crabby-images/99b65/99b65174be6cf859b23fe090d3935790d96d3791" alt="index.jpg"