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

144
作者 ohun
2016.08.26 16:42* 字数 841

引言

由于之前自己团队需要一个消息推送系统来替换JPUSH,一直找了很久基本没有真正可用的开源系统

所有就直接造了个轮子,造轮子的时候就奔着开源做打算的,只是后来创业项目失败一直没时间整理

这一套代码,最近比较闲就拿出来给开源做点贡献。

作为Java版的开源推送系统,MPush还是有很多不错的设计的,特别是对想自己搭建一套推送系统的团队

是有很大的借鉴意义的。当然开源出来也是不想曾经做过的工作白白浪费掉,特别希望对这方面有兴趣的同学

来一起把这套东西做的更好,服务更多的用户!


项目主页

https://mpusher.github.io


系统介绍


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


特性和优势

1. 源码全部开放,包括server、android、ios (不像有些开源服务只开放部分代码,鄙视下)

2. 代码质量高,全部模块化设计,真正的商用级产品,考虑到推送中遇到的大部分场景

3. 安全性高,基于RSA精简的加密握手协议,简单,高效,安全

4. 支持断线重连,及弱网下的快速重连,无网络下自动休眠节省电量和资源

5. 协议简洁,接口流畅,支持数据压缩,更加节省流量

6. 支持集群部署,支持负载均衡,基于成熟的zookeeper实现

7. 用户路由使用redis集群,支持单写,双写,集群分组;性能好,可用性高

8. 支持http代理,一根TCP链接接管应用大部分请求,让http请求更加及时

9. 高度可配置化,基本上通过修改配置可满足大部分场景

10. 扩展性强,高度模块化,基于SPI模式的可拔插设计,以满足特殊需求

11. 监控完善,日志详细,可快速排查线上问题及服务调优


教程与文档

开发手册:http://mpush.mydoc.io


源码

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源码

IOS sdk(swift) https://github.com/mpusher/mpush-client-swift swift版客户端源码

IOS sdk(OC) https://github.com/mpusher/mpush-client-oc Object C 客户端源码

websoket(JS) https://github.com/mpusher/mpush-client-js websocket js 客户端源码


帮助与支持

官网:https://mpusher.github.io

文档:http://mpush.mydoc.io

QQ群:114583699 

日记本