MPush基于java netty4的开源消息推送系统:简洁、安全、支持集群
2016-08-31 17:36
218 查看
公司要用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/mpushjava-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
相关文章推荐
- Android MPush开源消息推送系统:简洁、安全、支持集群
- MPush开源消息推送系统:简洁、安全、支持集群
- Kafka开源消息系统分布式集群搭建
- Nchan nginx 支持的开源消息推送模块
- 一共81个,开源大数据处理工具汇总:查询引擎、流式计算、迭代计算、离线计算、键值存储、表格存储、文件存储、资源管理、日志收集系统、消息系统、分布式服务、集群管理、基础设施、搜索引擎、数据挖掘=监控
- 一共81个,开源大数据处理工具汇总:查询引擎、流式计算、迭代计算、离线计算、键值存储、表格存储、文件存储、资源管理、日志收集系统、消息系统、分布式服务、集群管理、基础设施、搜索引擎、数据挖掘=监控
- 开源实时消息推送系统 MPush
- OSSIM(开源安全信息管理系统)在企业网络管理中的应用
- DotNetMQ-基于C#和.NET框架的开源消息队列系统 – 安装部署及消息发送接收范例
- 金坛市人民医院电子病历服务器及存储安全容灾集群系统设备项目
- 开源消息推送 Android push message 小试
- 开源资产管理软件—OCS Inventory NG+ GLPI 系统安装配置UTF-8版 支持中文
- Vsftpd完全攻略(三)基于系统用户支持ftp上传 访问和vsftp安全设置
- OceanBase,淘宝开源的千亿级别分布式数据库系统。支持读写事务的线上服务
- OceanBase,淘宝开源的千亿级别分布式数据库系统。支持读写事务的线上服务
- OSSIM(开源安全信息管理系统)在企业网络管理中的应用
- 开源信息安全管理系统 OSSIM
- IBM V7000容量翻番 支持双系统集群与10GbE
- DotNetMQ-基于C#和.NET框架的开源消息队列系统
- 智能机系统的消息推送比较