MPush开源消息推送系统:简洁、安全、支持集群
引言
由于之前自己团队需要一个消息推送系统来替换JPUSH,一直找了很久基本没有真正可用的开源系统
所有就直接造了个*,造*的时候就奔着开源做打算的,只是后来创业项目失败一直没时间整理
这一套代码,最近比较闲就拿出来给开源做点贡献。
作为Java版的开源推送系统,MPUSH还是有很多不错的设计的,特别是对想自己搭建一套推送系统的团队
是有很大的借鉴意义的。当然开源出来也是不想曾经做过的工作白白浪费掉,特别希望对这方面有兴趣的同学
来一起把这套东西做的更好,服务更多的用户!
项目主页
系统介绍
mpush,是一款开源的实时消息推送系统,采用java语言开发,服务端采用模块化设计,具有协议简洁,传输安全,接口流畅,实时高效,扩展性强,可配置化,部署方便,监控完善等特点。同时也是少有的可商用的开源推送系统。
特性和优势
-
源码全部开放,包括server、android、ios (不像有些开源服务只开放部分代码,鄙视下)
-
代码质量高,全部模块化设计,真正的商用级产品,考虑到推送中遇到的大部分场景
-
安全性高,基于RSA精简的加密握手协议,简单,高效,安全
-
支持断线重连,及弱网下的快速重连,无网络下自动休眠节省电量和资源
-
协议简洁,接口流畅,支持数据压缩,更加节省流量
-
支持集群部署,支持负载均衡,基于成熟的zookeeper实现
-
用户路由使用redis集群,支持单写,双写,集群分组;性能好,可用性高
-
支持http代理,一根TCP链接接管应用大部分请求,让http请求更加及时
-
高度可配置化,基本上通过修改配置可满足大部分场景
-
扩展性强,高度模块化,基于SPI模式的可拔插设计,以满足特殊需求
-
监控完善,日志详细,可快速排查线上问题及服务调优
服务调用关系
教程与文档
源码
- group https://github.com/mpusher/ 源代码空间
- server https://github.com/mpusher/mpush 服务端源码
- alloc https://github.com/mpusher/alloc 调度器源码
- mpns https://github.com/mpusher/mpns 个性化推送中心源码
- java-client https://github.com/mpusher/mpush-client-java 纯java客户端源码
- android sdk&demo https://github.com/mpusher/mpush-android 安卓SDK和DEMO源码
- IOS sdk(swift) https://github.com/mpusher/mpush-client-swift swift版客户端源码
- IOS sdk(OC) https://github.com/mpusher/mpush-client-oc Object C 客户端源码
帮助与支持
- 官网:https://mpusher.github.io
- 文档:https://mpusher.github.io/docs
- 群:114583699
上一篇: 一个使用Maven的HornetQ示例
下一篇: 硬盘重映射和待映射的什么意思