9 years of accumulation, precipitated a high-performance universal communication service, supporting instant messaging, in-site/system messages, message center, IoT communication, audio and video signaling, live broadcast barrage, customer service system, AI communication, instant community and other scenarios.
This project needs to be compiled in a go1.20.0 or higher environment.
Distributed IM important features: automatic failover, decentralized design, data mutual backup between nodes, support for rapid automatic cluster expansion, proxy node mechanism.
Chat Demo
Web chat scenario demo: http://imdemo.githubim.com
Backend monitoring demo: http://monitor.githubim.com/web
🎦Uniqueness
No limit on group members, easily supports 100,000 people group chat, messages can be stored permanently.
📚Low Resource Consumption
Self-developed binary protocol, heartbeat packet is only 1 byte, saving traffic, saving power, and faster transmission.
🔐Security
Message channels and message content are encrypted throughout, preventing man-in-the-middle attacks and message tampering, with real-time backup of server data to prevent data loss.
🚀 Performance
Based on the pebble kv database, a unique distributed database for IM services was developed, avoiding the performance loss caused by other databases' generality. Faster storage means faster messages.
🔥High Availability
Through a modified raft distributed protocol, automatic disaster recovery is achieved. If one machine fails, another machine automatically takes over without external perception.
Decentralized, no single point, no central node, each node is independent and equal, all can provide services.
Easy expansion, just add machines, no need to shut down, no need to migrate data, automatic data allocation according to strategy.
0⃣️ Ease of Use
Does not rely on any third-party middleware, simple deployment, can be started with one command.
Adopts the design concept of channel subscription and publishing, easy to understand, easy to use.
As simple as Redis, as high-performance as Kafka, as reliable as MySQL.
🌲Technical Support
Official team provides technical support, technical documentation, technical exchange group, and issue feedback.
git clone https://github.com/WuKongIM/WuKongIM.git
cd WuKongIM/docker/cluster
sudo docker compose up -d
Backend Management System: http://127.0.0.1:15300/web
Chat Demo Address: http://127.0.0.1:15172/login
go run main.go
(go run main.go --config config/wk.yaml)
# Start the first node
go run main.go --config ./exampleconfig/cluster1.yaml
# Start the second node
go run main.go --config ./exampleconfig/cluster2.yaml
# Start the third node
go run main.go --config ./exampleconfig/cluster3.yaml
Backend Management System: http://127.0.0.1:5300/web
Chat Demo Address: http://127.0.0.1:5172/chatdemo
Formal Deployment
DocsDocs
Project Name | Github Address | Example | Documentation | Description |
---|---|---|---|---|
WuKongIM | Github | 无 | Documentation | WuKongIM communication end, responsible for long connection maintenance, message delivery, etc. |
WuKongIMAndroidSDK | Github | Example | Documentation | WuKongIM's Android SDK |
WuKongIMiOSSDK | Github | Example | Documentation | WuKongIM's iOS SDK |
WuKongIMUniappSDK | Github | Example | Documentation | WuKongIM's Uniapp SDK |
WuKongIMJSSDK | Github | Example | Documentation | WuKongIM's JS SDK |
WuKongIMFlutterSDK | Github | Example | Documentation | WuKongIM's Flutter SDK |
WuKongIMReactNativeDemo | Github | None | None | WuKongIM's React Native Demo (provided by contributor wengqianshan) |
Architecture
Business System Integration
Webhook
Our team has been committed to the research and development of instant messaging. We need your encouragement. If you find this project helpful, please give it a star. Your support is our greatest motivation.
Project
TangSengDaoDao
Github
https://github.com/TangSengDaoDao/TangSengDaoDaoServer
Screenshot
If necessary, add me and I will invite you to the group. My WeChat ID is wukongimgo.
WuKongIM is licensed under the Apache License 2.0.
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。
1. Open source ecosystem
2. Collaboration, People, Software
3. Evaluation model