MPush开源消息推送系统:简洁、安全、支持集群

引言
由于之前自己团队需要一个消息推送系统来替换JPUSH,一直找了很久基本没有真正可用的开源系统
所有就直接造了个轮子,造轮子的时候就奔着开源做打算的,只是后来创业项目失败一直没时间整理
这一套代码,最近比较闲就拿出来给开源做点贡献。
作为Java版的开源推送系统,MPUSH还是有很多不错的设计的,特别是对想自己搭建一套推送系统的团队
是有很大的借鉴意义的。当然开源出来也是不想曾经做过的工作白白浪费掉,特别希望对这方面有兴趣的同学
来一起把这套东西做的更好,服务更多的用户!

项目主页https://mpusher.github.io

系统介绍
mpush,是一款开源的实时消息推送系统,采用java语言开发,服务端采用模块化设计,具有协议简洁,传输安全,接口流畅,实时高效,扩展性强,可配置化,部署方便,监控完善等特点。同时也是少有的可商用的开源push推送系统。

特性和优势
1. 源码全部开放,包括server、android、ios (不像有些开源服务只开放部分代码,鄙视下)
2. 代码质量高,全部模块化设计,真正的商用级产品,考虑到推送中遇到的大部分场景
3. 安全性高,基于RSA精简的加密握手协议,简单,高效,安全
4. 支持断线重连,及弱网下的快速重连,无网络下自动休眠节省电量和资源
5. 协议简洁,接口流畅,支持数据压缩,更加节省流量
6. 支持集群部署,支持负载均衡,基于成熟的zookeeper实现
7. 用户路由使用redis集群,支持单写,双写,集群分组;性能好,可用性高
8. 支持http代理,一根TCP链接接管应用大部分请求,让http请求更加及时
9. 高度可配置化,基本上通过修改配置可满足大部分场景
10. 扩展性强,高度模块化,基于SPI模式的可拔插设计,以满足特殊需求
11. 监控完善,日志详细,可快速排查线上问题及服务调优

教程与文档
开发手册https://mpusher.github.io/docs


源码




帮助与支持

原文地址:https://www.cnblogs.com/ohun/p/5906591.html