PUSH消息推送的实现原理(push消息推送的实现原理是什么)

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

编辑导语:如今,push已经成为了我们手机信息流的一种推广方式,那么push消息推送是如何实现的呢?作者总结了几种消息推送的类型以及实现原理,一起来看看。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

一、消息推送的类型

1. 短信推送

指通过运营商将文本或数字消息传递至用户手机或其他电信终端。它凭借着优秀的发送率和到达率,一度成为最受欢迎的营销工具之一。

一般企业不太会直接对接移动、联通、电信来实现短信发送,而是通过中间的服务商将各地区的运营商资源整合后提供统一、便捷的短信服务,这类服务商叫短信服务商,也可叫短信SP。

目前,支持个人短信服务的厂商有阿里云腾讯云,其他厂商都是需要认证为企业用户才能使用短信服务平台。短信供应商根据发送量进行收费,发送越多单价越便宜。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

2. 邮件推送

EDM(Email Direct Marketing),即电子邮件营销。企业可以通过EDM建立同目标顾客的沟通渠道,向其直接传达相关信息,用来促进销售。邮件推送具有精准送达、个性化定制、内容格式丰富的特点。亚马逊就曾凭借优秀的电子邮件营销出圈。

3. 微信消息推送

截至2022年3月31日,微信及WeChat的合并月活跃账户数为12.883亿。随着微信的影响力的增强,越来越多的企业也逐渐重视微信生态的布局,微信消息推送就是其一,它的到达率高、支持精准推送。不足的是,其内容受限于模板,且微信提供的模板数量有限,一个公众号最多选用25种模板。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

4. 通知栏推送

通知栏推送,也被称为PUSH推送,即在手机终端锁屏状态下通知栏展示或在操作前台顶端弹出的消息通知。用户可以在移动设备锁定屏幕和通知栏看到push消息通知,通知栏点击可唤起APP并去往相应页面。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

5. 应用内推送

应用内推送常见的形式有弹窗、顶部悬浮通知、收件箱等,可由应用自行控制样式和内容格式。不足的是只能在用户在线时查看,触达有限。

二、移动推送的三种实现方式

在本篇文章中主要介绍通知栏推送的实现方法。在了解具体的推送原理之前,我们先来了解下移动推送的三种实现方式。

1. 轮询方式(PULL)

客户端和服务器定期地建立连接,通过消息队列等方式来查询是否有新的消息,需要控制连接和查询的频率,频率不能过慢或过快,过慢会导致部分消息更新不及时,过快会消耗更多的资源(流量、电量等),对用户体验有较大伤害。

2. 短信推送方式(SMS PUSH)

通过短信发送推送消息,并在客户端植入短信拦截模块(主要针对 Android 平台),可以实现对短信进行拦截并提取其中的内容转发给 App 应用处理,这个方案借助于运营商的短消息,能够保证最好的实时性和到达率,但此方案对于成本要求较高,开发者需要为每一条 SMS 支付费用。

3. 长连接方式(PUSH)

客户端主动和服务器建立 TCP 长连接之后, 客户端定期向服务器发送心跳包用于保持连接, 有消息的时候, 服务器直接通过这个已经建立好的 TCP 连接通知客户端。

尽管长连接也会造成一定的开销,对于轮询和 SMS 方案的硬伤来说,目前已经是最优的方式,而且通过良好的设计,可以将损耗降至最低。不过,随着客户端数量和消息并发量的上升,对于消息服务器的性能和稳定性要求提出了非常大的考验。因此,就难度而言,此方式代价最高。

基于上面的介绍,我们可以知道长连接方式是移动推送中目前最优的方案,它也是当前主流的推送方式,基于该推送方式逐步发展出系统级、应用级一系列的推送解决方案。

三、系统级推送解决方案

1. iOS 平台(APNs)

iOS 在系统层面与苹果 APNs(Apple Push Notification service)服务器建立连接,不论App是在线状态还是离线状态,消息推送至iOS的APNS服务器,APNS再根据设备标识推送至指定设备,用户即可接收到消息。

大致链路为:业务系统(发起推送)——第三方消息推送服务商或自建消息推送系统的服务器(推送逻辑控制、推送下发)——苹果APNS服务器——指定用户设备。

整个过程很清晰,并且所有 APP 都共用同一个系统级的连接,减少了系统开销,虽然 APNs 能无障碍的访问,但实际使用过程中,也会存在延时和丢消息的情况。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

2. Android 平台

Android 的 C2DM(Android Cloud to Device Messaging)采取与 iOS 类似的机制,都是由系统层面来支持消息推送,但是由于 Google 的服务在国内不能稳定的访问,此方案对于中国用户来说基本是无法使用的。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

除了 Google 官方提供的方案,中国众多的手机厂商在其定制的系统中也内置了推送功能,如小米、华为等。不过在建立推送服务之前,需要申请开发者账号并绑定App,在开放平台开通厂商通道推送的权限。这类厂商机型支持在线离线状态的消息推送。

消息推送大致链路为:业务系统(发起推送)——第三方消息推送服务商或自建消息推送系统的服务器(推送逻辑控制、推送下发)——厂商服务器——指定用户设备。

四、应用级推送解决方案

1. 第三方推送服务

鉴于 Android 平台 C2DM 推送的不可用性,国内涌现出大量的第三方推送服务提供商。目前应用最为广泛的第三方推送服务提供商包括个推、极光、友盟、小米、华为、BAT 等,绝大部分 APP 都会优先考虑采用第三方推送服务。

2. 自建推送服务

第三方服务在开发成本和消息到达率上表现都不错,但所有信息会经过第三方服务器,对于信息敏感类 APP 而言,有必要考虑自建一套消息推送服务,能最大化保证安全,但自建推送服务需要对 App 客户端海量长连接的维护管理且面临保证 Push Service 常驻的难题等。

五、PUSH推送实现方法总结

综合以上分析,推送实现方式可以简单概括为:

PUSH消息在消息系统创建好后进入发送阶段,服务端根据用户终端信息进行路由,调用苹果自身的推送通知服务(APNs)或根据根据不同的安卓厂商去调用对应的SDK,最后下达到用户设备。

当然,如果是通过之前说过的个推、极光等推送服务商,那么内部的服务端就无需做这些繁琐的开发工作。他们不仅集成了APNS、小米、华为等大部分厂商通道,还可覆盖微信公众号、微信小程序、短信、邮件、支付宝生活号、钉钉企业微信、5G消息、飞书等,同时在补发策略、数据监控等层面也有较为成熟的方案。

PUSH消息推送的实现原理(push消息推送的实现原理是什么)

话又说回来,对于产品经理来说,上述内容只需要了解就可以了,我们更关注的还是如何利用推送提升业务转化和用户体验。至于你问我那为什么还要写,当你从0搭建一个app时,就能感同身受了。

作者:阿宅的产品笔记;公众号:阿宅的产品笔记(PMZZnote)

本文由 @公众号阿宅的产品笔记 原创发布于人人都是产品经理。未经许可,禁止转载。

题图来自Unsplash,基于CC0协议。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年3月29日 上午9:28
下一篇 2024年3月29日 上午9:42

相关推荐

  • 简单的管理信息系统案例(管理信息业务流程系统)

    管理信息业务流程系统是一种重要的信息技术,可以帮助企业更好地管理业务流程。本文将介绍管理信息业务流程系统的特点和作用,并探讨如何使用该系统来提高企业的效率和质量。 一、管理信息业务…

    科研百科 2024年6月7日
    47
  • HUB系统集成项目管理

    HUB系统集成项目管理 摘要: HUB系统集成项目管理是一项重要的工作,涉及到多个部门和利益相关者之间的协调和合作。本文将介绍HUB系统集成项目管理的基本概念、流程和方法,包括需求…

    科研百科 2024年12月30日
    1
  • 安丘市财政局创新工作举措 全方位推进内部控制建设

    安丘市财政局高度重视内部控制工作,深入贯彻推进内控建设的总体要求,从组织领导、制度修订、机制执行、科室协同、信息化建设、成果应用等方面大力推动内部控制建设。今年,通过创新性开展内控…

    科研百科 2023年1月25日
    134
  • 广告机管理系统项目文档

    广告机管理系统项目文档 一、项目概述 广告机管理系统是一个用于管理广告机设备的工具,能够帮助企业更好地控制广告机的使用和管理。该系统包括广告机硬件的管理、广告机的部署、广告机的监控…

    科研百科 2024年12月31日
    1
  • 吉林省科技厅科研项目申报吉林省科技厅科研项目申报

    吉林省科技厅科研项目申报 随着科技的不断发展,吉林省科技厅一直致力于推动科技创新。作为一项促进科技发展的重要措施,吉林省科技厅正在推出一系列科研项目,为科研人员提供丰富的研究机会和…

    科研百科 2024年9月9日
    19
  • 非公党建先锋|豪顺精密:以党建带动企业发展(豪顺服饰有限公司)

    编者按: 非公经济党组织扮演了党建引领的角色,打造了一个个堪当重任、创赢未来的一流团队。为此,东莞市工商联(总商会)、南方 客户端东莞工商联频道、市非公经济组织党委通过采访多家党建…

    科研百科 2023年9月27日
    77
  • 课题应该用什么符号括起来

    课题括起来应该用什么符号,这个问题在不同的语境中可能有不同的答案。一般来说,课题括起来可以用圆括号(`)来括起来,也可以用方括号([])括起来。 圆括号(`)用于括起来较小的、比较…

    科研百科 2024年12月9日
    4
  • 王祥喜:全面提高机关党建质量为履行应急管理职责使命提供坚强保证

    王祥喜在应急管理部党委会部务会上强调 全面提高机关党建质量 为履行应急管理职责使命提供坚强保证 5月4日,应急管理部党委书记、部长王祥喜主持召开部党委会和部务会,传达学习2023年…

    科研百科 2024年5月30日
    68
  • 宽甸政务协同办公系统

    宽甸政务协同办公系统:优化政务流程,提高服务水平 随着信息技术的不断发展,宽甸政务协同办公系统已经成为当前政务工作的重要组成部分。这个系统为宽甸政务工作提供了更加高效,便捷,可靠的…

    科研百科 2024年9月22日
    15
  • 工程项目管理云软件

    工程项目管理云软件:实现高效协同的数字化工具 随着信息技术的不断发展,工程项目管理云软件已经成为了现代工程项目管理中不可或缺的一部分。工程项目管理云软件能够帮助工程项目管理人员高效…

    科研百科 2024年9月22日
    18