消息推送的原理分析

所有的推送功能必须有一个客户端和服务器的长连接,因为推送是由服务器主动向客户端发送消息,如果客户端和服务器之间不存在一个长连接那么服务器是无法来主动连接客户端的。因而推送功能都是基于长连接的基础是上的。

iOS长连接是由系统来维护的,也就是说苹果的iOS系统在系统级别维护了一个客户端和苹果服务器的长链接,iOS上的所有应用上的推送都是先将消息推送到苹果的服务器然后将苹果服务器通过这个系统级别的长连接推送到手机终端上,这样的的几个好处为:

在手机终端始终只要维护一个长连接即可,而且由于这个长连接是系统级别的不会出现被杀死而无法推送的情况。
省电,不会出现每个应用都各自维护一个自己的长连接。 
安全,只有在苹果注册的开发者才能够进行推送,等等。 
android的长连接是由每个应用各自维护的,但是google也推出了和苹果技术架构相似的推送框架,C2DM,云端推送功能,但是由于google的服务器不在中国境内,其他的原因你懂的。所以导致这个推送无法使用,android的开发者不得不自己去维护一个长链接,于是每个应用如果都24小时在线,那么都得各自维护一个长连接,这种电量和流量的消耗是可想而知的。虽然国内也出现了各种推送平台,但是都无法达到只维护一个长连接这种消耗的级别。