看了看极光推送的原理,还不是太明白,现在记录下来,供以后深究。原文如下: 

 移动互联网应用现状

  因为手机平台本身、电量、网络流量的限制,移动互联网应用在设计上跟传统 PC 上的应用很大不一样,需要根据手机本身的特点,尽量的节省电量和流量,同时又要尽可能的保证数据能及时到达客户端。

  为了解决数据同步的问题,在手机平台上,常用的方法有2种。一种是定时去服务器上查询数据,也叫Polling,还有一种手机跟服务器之间维护一个 TCP 长连接,当服务器有数据时,实时推送到客户端,也就是我们说的 Push。

  从耗费的电量、流量和数据送达的及时性来说,Push 都会有明显的优势,但 Push 的实现和维护成本相对较高。在移动无线网络下维护长连接,相对也有一些技术上的难度。本文试图给大家介绍一下我们极光推送在 Android 平台上是如何维护长连接。

  移动无线网络的特点

  因为 IP v4 的 IP 量有限,运营商分配给手机终端的 IP 是运营商内网的 IP,手机要连接 Internet,就需要通过运营商的网关做一个网络地址转换(Network Address Translation,NAT)。简单的说运营商的网关需要维护一个外网 IP、端口到内网 IP、端口的对应关系,以确保内网的手机可以跟 Internet 的服务器通讯。

  

  图片源自 cisco.com.

  NAT 功能由图中的 GGSN 模块实现。

  大部分移动无线网络运营商都在链路一段时间没有数据通讯时,会淘汰 NAT 表中的对应项,造成链路中断。

  Android 平台上长连接的实现

  为了不让 NAT 表失效,我们需要定时的发心跳,以刷新 NAT 表项,避免被淘汰。

  Android 上定时运行任务常用的方法有2种,一种方法用 Timer,另一种是AlarmManager。

  Timer

  Android 的 Timer 类可以用来计划需要循环执行的任务,Timer 的问题是它需要用 WakeLock 让 CPU 保持唤醒状态,这样会大量消耗手机电量,大大减短手机待机时间。这种方式不能满足我们的需求。

  AlarmManager

  AlarmManager 是 Android 系统封装的用于管理 RTC 的模块,RTC (Real Time Clock) 是一个独立的硬件时钟,可以在 CPU 休眠时正常运行,在预设的时间到达时,通过中断唤醒 CPU。

  这意味着,如果我们用 AlarmManager 来定时执行任务,CPU 可以正常的休眠,只有在需要运行任务时醒来一段很短的时间。极光推送的 Android SDK 就是基于这种技术实现的。

  服务器设计

  当有大量的手机终端需要与服务器维持长连接时,对服务器的设计会是一个很大的挑战。

  假设一台服务器维护10万个长连接,当有1000万用户量时,需要有多达100台的服务器来维护这些用户的长连接,这里还不算用于做备份的服务器,这将会是一个巨大的成本问题。那就需要我们尽可能提高单台服务器接入用户的量,也就是业界已经讨论很久了的 C10K 问题。

  C2000K

  针对这个问题,我们专门成立了一个项目,命名为C2000K,顾名思义,我们的目标是单机维持200万个长连接。最终我们采用了多消息循环、异步非阻塞的模型,在一台双核、24G内存的服务器上,实现峰值维持超过300万个长连接。

  后记

  稳定维护长连接是推送平台的一个基础,极光推送团队将会在这方面长期投入,以保证用户能有效的节省电量、流量,同时数据能实时送达。

极光推送技术原理:移动无线网络长连接(转自eoe移动开发门户)相关推荐

  1. 看了极光推送技术原理的几点思考

    看了极光推送技术原理的几点思考 分类: android2012-11-26 20:50 16586人阅读 评论(18) 收藏 举报 目录(?)[+] 移动互联网应用现状 因为手机平台本身.电量.网络流 ...

  2. 个推和极光推送技术介绍

    一.概念 1.早期推送服务 在移动互联网以前的手机,如果有事情发生要通知用户,则会弹出一个窗口,告诉用户正在发生的事,可能是未接电话提示.日历提醒或是一封彩信.推送功能最早是被用于Email中,而目前 ...

  3. Web端服务器推送技术原理分析及dwr框架简单的使用

    转载:http://blog.csdn.net/shimiso/article/details/8151362 1 背景 "服务器推送技术"(ServerPushing)是最近We ...

  4. 服务器推送技术原理分析及dwr框架简单的使用

    1        背景 "服务器推送技术"( ServerPushing)是最近 Web技术中最热门的一个流行术语.它是继" Ajax "之后又一个倍受追捧的  ...

  5. php消息实时推送技术,基于HTTP协议之WEB消息实时推送技术原理及实现

    很早就想写一些关于网页消息实时推送技术方面的文章,但是由于最近实在忙,没有时间去写文章.本文主要讲解基于 HTTP1.1 协议的 WEB 推送的技术原理及实现.本人曾经在工作的时候也有做过一些用到网页 ...

  6. Android之基于xmpp openfire smack开发之Android消息推送技术原理分析和实践[4]

    http://blog.csdn.net/shimiso/article/details/8156439 前面几篇给大家系统讲解的有关xmpp openfire smack asmack相关的技术和使 ...

  7. Android中极光推送

    一. 概念: 极光推送(JPush)是一个端到端的推送服务,使得服务器端消息能够及时地推送到终端用户手机上,让开发者积极地保持与用户的连接,从而提高用户活跃度.提高应用的留存率.极光推送客户端支持 A ...

  8. Android 推送实现原理解析

    目录 一.什么是推送? 二.解决数据同步的问题 三.移动无线网络的特点 四.Android 平台上长连接的实现 五.服务器设计 六.消息推送的一般有的方式 七.参考资料 一.什么是推送? 消息推送最简 ...

  9. HTTP长连接和短连接以及推送服务原理(转)

    HTTP长连接和短连接以及推送服务原理 转自:http://blog.csdn.net/freewaywalker/article/details/50067757 HTTP长连接和短连接1 1. H ...

最新文章

  1. 动易html编辑器,文章内容一键排版功能——动易5.1版新特性
  2. 2017年第八届蓝桥杯C/C++ C组国赛 —— 第四题:小数第n位
  3. 隐藏esp_仅需一分钟教你看懂汽车内的隐藏功能,哪些功能是你不知道的?
  4. 开发者论坛一周精粹(第十九期) :【重要事件】运维人员注意啦:NetSarang的Xmanager和Xshell多种产品被植入后门...
  5. 1130 无法登录 mysql_无法登录phpmyadmin,报1130错误
  6. Facebook怎样开发软件:工程师驱动的文化
  7. 电机学第一章(磁路的基本定律)
  8. PPP开源软件GMAP测试记录及原始数据比较
  9. 推荐Go语言开源项目:Excelize ,获取阿里云ECS实例监控数据导出到自定义Excel表格(二)
  10. 数据结构与算法分析(一)基础
  11. 通过2048学习自定义view(一)
  12. 输入输出练习 python
  13. 2020腾讯实习生客户端三轮面经
  14. Django计算机毕业设计餐饮管理系统(程序+LW)Python
  15. 删除docker container
  16. 基于unity自己写光追。
  17. APNG面向移动与未来的新动画图片格式揭秘与制作全技巧
  18. QQ群头像 微信群头像 多图合并框架实现
  19. 动态图册用HTML怎么制作,imgplay gif动图制作如何使用?imgplay图文使用教程
  20. JTAG篇(2)——FT2232H 控制 JTAG TAP

热门文章

  1. 国际物流中的拖车报关及流程是怎样的?
  2. [转载]使用正则表达式验证本地化数据
  3. 无法启动此程序 因为计算机中丢失xlive,光环2xlive.dll文件丢失的解决方法
  4. 道德三皇五帝,功名夏后商周.(中英文版)
  5. Matlab中创建函数句柄
  6. 如何解决 尝试加载 Oracle 客户端库时引发 BadImageFormatException
  7. Linux下安装Redis教程
  8. 这个网站 精确的北京时间 是如何获取的
  9. 计算机专业的硕士犯罪,中国刑事警察学院计算机犯罪侦查系介绍
  10. Citrix XenServer虚拟机安装详细过程图文教程