有个客户端集成了 MQTT 库,在前台运行时,MQTT 消息可以正常接收和发送。 但是放在后台后, 消息就收不到了。
有办法让 MQTT service 一直运行吗?
1 y830CAa5nink4rUQ 2022-06-22 11:50:35 +08:00 ![]() 俗称保活,目前这是一门高精尖技术活。 |
2 nothingistrue 2022-06-22 11:52:06 +08:00 后台接受消息,请使用推送,除了微信之外的强行保活手段,必然被 OEM 和用户无情的杀掉。 |
3 passon 2022-06-22 11:54:11 +08:00 目前已经没有稳定的包活手段了。可以 App 挂了后应该走厂商推送 |
![]() | 4 crayygy 2022-06-22 12:02:06 +08:00 Foreground Service |
![]() | 5 psklf 2022-06-22 12:12:35 +08:00 Foreground Service 应该可以 |
![]() | 6 springz 2022-06-22 12:29:59 +08:00 看设备是不是自己能控制的,自己定制一个 ROM 加白名单。 |
![]() | 7 springz 2022-06-22 12:31:06 +08:00 Foreground services 不行的,还是会断。 |
![]() | 8 springz 2022-06-22 12:33:47 +08:00 保活目前是超级技术活,有能量就厂商白名单,比如微信。没能量就老老实实推送。不过国内这推送,唉。多集成几个厂商推送吧。 |
![]() | 9 springz 2022-06-22 12:35:33 +08:00 看什么应用,要是不是 toC 的,特定领域的,大不了一直放着音乐,霸占一个通知栏,也能活。 |
![]() | 10 springz 2022-06-22 12:38:15 +08:00 放音乐这个要是进程被杀了,也拉不起来的。总之现在要是要求一直在线就厂商白名单吧,看自己公司有没有这个能量。 |
![]() | 11 springz 2022-06-22 12:39:17 +08:00 用这个怼需求提出方也行,有这需求找手机厂商解决。 |
12 leafre 2022-06-22 12:47:57 +08:00 无解,换种实现方式 |
14 cczhrd 2022-06-22 13:54:47 +08:00 |
![]() | 15 darkengine 2022-06-22 14:17:32 +08:00 这要是做到了,国外不敢讲,国内互联网大厂随便挑哈 |
16 aneostart173 2022-06-22 16:54:16 +08:00 挺难的,而且一年比一年难。老实用推送,或者自己定制设备。 |
17 BlackBull19 2022-06-22 16:55:42 +08:00 只能推荐推送了. 搞一个坚挺前后台切换的 然后走推送, 目前只能推送 |
![]() | 18 lqzhgood 2022-06-22 18:13:21 +08:00 提示用户把 App 加入后台自启动能保活吗? |
![]() | 19 cheng6563 2022-06-22 18:14:50 +08:00 引导客户再设置里加后台运行白名单,别无他法。 |
21 basncy 2022-06-22 20:10:16 +08:00 ![]() 包名改成 com.tencent.mobileqq |
![]() | 22 PowerDi 2022-06-2 20:18:44 +08:00 原来现在已经那么严重了吗?保活都需要专门的思路了? |
![]() | 23 PowerDi 2022-06-22 20:19:34 +08:00 如果保活那么困难,现在为什么那么多安卓用户还在苦于后台 CPU 在猛跑 |
24 basncy 2022-06-22 20:20:59 +08:00 android 再先进的调度算法, 研究再多保活代码, 再多设置, 在这里可能就被某些国行厂商后台优化白名单一刀切了, 21 楼简单以暴制暴. |
![]() | 25 SupperMary 2022-06-22 21:07:15 +08:00 @PowerDi 厂家和 APP 有 py 交易 |
![]() | 26 darkengine 2022-06-22 21:12:16 +08:00 @basncy 如果用户先安装了 qq ,这个包名的 apk 都安装不了。。。 |
![]() | 27 zinwalin OP @nothingistrue 如果是自己的定制安卓系统,有什么好办法保活吗? 我试了在系统级 App 里集成 MQTT Service ,放后台后,一样会收不到消息。 |
![]() | 31 springz 2022-06-22 21:53:47 +08:00 自己定制的系统随便玩啊,找编译 ROM 的人把你 App 加进去。 |
![]() | 32 tanranran 2022-06-22 21:54:42 +08:00 如果是定系统级,把 APP 放到 /system/priv-app/下即可 |
![]() | 34 300 2022-06-22 22:36:30 +08:00 via Android dumpsys deviceidle whilelist +com.xxx 你都定制系统了,怎么后台权限还搞不定… |
35 SteveWoo 2022-06-22 22:57:08 +08:00 ![]() 不可能了,尤其是国外的文章不适合国情。 去 android 上把微信的白名单关了,微信去后台都收不到消息的。 国产厂商默认把微信加白名单,如果你们有实力去跟厂家谈谈。 |
![]() | 36 zinwalin OP @winterbells 感谢,dumpsys deviceidle whilelist +com.xxx 这台命令,如果不通过命令行,怎么默认加到系统里? 也就是编译时在哪里添加? |
![]() | 37 documentzhangx66 2022-06-22 23:36:22 +08:00 别的系统我不知道,小米系统就可以这样: 写个 APP 承载服务,然后让用户去系统里设置,该 APP 在后台能一直存活,不被限制。 |
![]() | 38 passerby233 2022-06-23 02:41:24 +08:00 via Android 参考这个库 https://github.com/hannesa2/paho.mqtt.android 然后在客户端的权限管理里开启自启动,电池省电策略更改为无限制就行了。 |
![]() | 39 treblex 2022-06-23 04:51:59 +08:00 |
40 nothingistrue 2022-06-23 09:27:25 +08:00 ![]() @PowerDi #23 高频激活被杀再激活这个循环,相比于单纯的常驻后台,CPU 消耗量可以多成百上千倍。Android 最大的问题不是常驻后台,而是自动唤醒方式多如牛毛。正常的常驻后台服务是消耗非常少的资源的(谷歌自带框架就是典型,几十个后台服务但是耗电量几乎无感) |
41 C603H6r18Q1mSP9N 2022-06-23 09:44:45 +08:00 1 开启悬浮权限 2 挂到 push 的 sdk 里面 |
![]() | 42 zinwalin OP @passerby233 谢谢分享,我现在用的是 implementation 'org.eclipse.paho:org.eclipse.paho.client.mqttv3:1.2.4' // MQTT implementation 'org.eclipse.paho:org.eclipse.paho.android.service:1.1.1' // MQTT service 你发的那个链接,是不是改过的? |
![]() | 43 passerby233 2022-06-23 10:03:28 +08:00 via Android @zinwalin 是的,就是基于 eclipse 版本的 mqtt 库改的,改成 kotlin 版本的了,提供的功能都一致的。 |
![]() | 44 zinwalin OP @passerby233 多谢。 |
![]() | 45 zinwalin OP @shanghai1998 方便给下相关的文章或资料吗? 多谢 |
![]() | 46 passerby233 2022-06-23 11:22:16 +08:00 |
![]() | 47 zinwalin OP @passerby233 感谢分享 |