MPush基于java netty4的开源消息推送系统:简洁、安全、支持集群

公司要用java做一个消息推送服务,打算底层用netty4实现,奈何资料较少。当调研了一段时间,绝望无助之际,mpush,横空出世,这个开源项目无疑给我们雪中送炭,不多说,下面是作者对它的介绍。


引言

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

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

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

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

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

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

项目主页

https://mpusher.github.io

系统介绍

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

特性和优势

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

源码

server https://github.com/mpusher/mpush

java-client https://github.com/mpusher/mpush-client-java

android sdk&demo https://github.com/mpusher/mpush-android

iOS sdk https://github.com/mpusher/mpush-client-swift

  • 官网:https://mpusher.github.io
  • 文档:https://mpusher.github.io/docs
  • QQ群:114583699 MPUSH开源消息推送系统


你可能感兴趣的:(推送,netty,java)