Google如何实施其推送通知功能?它是通过在后台运行或以其他方式运行的服务完成的轮询来工作的吗?
Google如何实施其推送通知功能?它是通过在后台运行或以其他方式运行的服务完成的轮询来工作的吗?
Answers:
根据我在以色列举行的Android开发者大会上所听到的话:
在Google云端服务器上,只有一个TCP套接字在接受模式下等待。TCP连接已由Google Play应用程序启动。因此,必须在设备上安装Google Play才能使Google Cloud Messaging(GCM)(以前称为Android Cloud to Device Messaging Service- C2DM)正常工作。
当此TCP客户端套接字收到某些消息时,该消息包含信息,例如应寻址的应用程序的程序包名称,当然还有数据本身。解析此数据并将其打包为一个意图,该意图将由应用程序广播并最终被接收。
即使设备的无线电状态变为“空闲”模式,TCP套接字仍保持打开状态。应用程序不必运行即可接收意图。
Android会保持与Google服务器的活动连接,但是它并不会消耗太多电力或数据,因为直到有人向您手机上的应用程序发送Google Cloud Messaging(GCM)消息之前,它都不会发送流量。手机上只有一个连接,所有应用程序都使用该连接:安装使用GCM的新应用程序不会增加任何额外的负载。
GCM的第一步是第三方服务器(例如电子邮件服务器)将请求发送到Google的GCM服务器。然后,该服务器通过该打开的连接将消息发送到您的设备。Android系统会查看该消息,以确定其适用于哪个应用程序,然后启动该应用程序。该应用程序必须已在Android上注册才能使用GCM,并且必须具有相关权限。应用启动时,它可能会立即创建一条通知,其中包含消息中的数据。GCM消息的大小非常有限,因此该应用可能会打开与第三方服务器的常规连接以获取更多信息(例如,下载新电子邮件的标头)。
使用推送通知的优点是应用程序不必定期运行以检查新数据,从而节省了电量和数据。使用GCM这样的集中机制的优势在于,该设备仅需要一个开放的网络连接,而Android GCM系统是唯一需要保持运行的系统,而不是每个应用程序都必须在后台保持运行以保持自己的网络连接到自己的服务器。
截至2018年4月10日,谷歌已弃用GCM。不建议使用GCM服务器和客户端API,并将于2019年4月11日将其删除。将GCM应用程序迁移到Firebase Cloud Messaging(FCM),它继承了可靠且可扩展的GCM基础架构以及许多新功能。
在Android设备上,当您收到推送通知时,发件人应用程序的图像和消息会显示在状态栏中。确切地说,当客户点击通知时,他/她就进入了应用程序。