草庐IT

android - 处理和解决 "Excessive network usage (background)"的正确方法

coder 2023-06-08 原文

问题背景

目前,我们面临来自 Android Vital 报告的“网络使用过多(背景)”。过去 30 天为 0.04%,但我们仅优于 9%

  • 过去 30 天 - 0.04%
  • 基准 - 优于 9%

因为只有 优于 9% 看起来很可怕。我们决定认真研究这个问题。

该应用程序是一个笔记应用程序 (https://play.google.com/store/apps/details?id=com.yocto.wenote),它提供了一个可选功能 - 应用程序关闭后在后台同步到云端。

这就是我们在后台执行同步到云的方式。

  1. 我们使用 WorkManager
  2. 在应用程序 onPause 中,调度 OneTimeWorkRequest,并带有约束 NetworkType.CONNECTED。工作人员计划以延迟 8 秒启动。
  3. 如果失败,我们会使用 BackoffPolicy.LINEAR 重试,延迟时间为 1.5 小时。
  4. 最大重试次数为 1 次。这意味着,在应用程序关闭后,直到应用程序再次重新打开。同步到云进程的最大执行次数为 2。
  5. 数据大小不一,从几 KB 到几百 MB。

我们如何执行同步的其他信息

  1. 我们正在使用 Google Drive REST API .
  2. 我们正在从 Google Drive App Data 文件夹下载一个 zip 文件,在本地执行数据合并,然后 zip,然后将单个 zip 文件重新上传回 Google Drive App Data 文件夹。
  3. zip 文件的大小可以从几 KB 到几百 MB。这是因为我们的笔记应用支持图片作为附件。

分析

我们拥有的唯一信息是https://developer.android.com/topic/performance/vitals/bg-network-usage .

When an app connects to the mobile network in the background, the app wakes up the CPU and turns on the radio. Doing so repeatedly can run down a device's battery. An app is considered to be running in the background if it is in the PROCESS_STATE_BACKGROUND or PROCESS_STATE_CACHED state. ... ... ... Android vitals considers background network usage excessive when an app is sending and receiving a combined total of 50 MB per hour while running in the background in 0.10% of battery sessions.

  1. 我们在 ApplicationonPause 8 秒后开始后台同步作业。在此期间,是否会在 PROCESS_STATE_BACKGROUND/PROCESS_STATE_CACHED 内部或外部的应用程序?我们如何避免在 PROCESS_STATE_BACKGROUND/PROCESS_STATE_CACHED 内运行?
  2. 在 0.10% 的电池 session 中在后台运行。”是什么意思?我们怎样才能避免这种情况?
  3. 另一个假设,是同步文件太大,使用了太多数据。很快,我们注意到这个假设可能不正确。我们注意到,根据“每小时移动网络使用情况(后台)”,数据大小在 0MB 到 5MB 之间。


问题

我的问题是

  1. 此类“网络使用过多(背景)”警告的实际根本原因是什么?我们如何才能准确地找出根本原因。
  2. 其他执行后台同步的应用(如 Google Photo、Google Keep、Google Doc...)如何解决这个问题?

最佳答案

对于您的第一个问题,“过度网络使用(后台)”在以下情况下触发:

... an app is sending and receiving a combined total of 50 MB per hour while running in the background in 0.10% of battery sessions. A battery session refers to the interval between two full battery charges.

Source

要确定造成这种情况的原因,请尝试使用 Battery Historian随着时间的推移分析您的应用的电池使用情况。对我们来说,它有助于识别我们不打算引入的重复唤醒锁。

下面是一个输出示例,向我们展示了过度的 BLE 扫描正在对电池造成重大影响:


对于您的第二个问题,WorkManager 可能是您所追求的,正如您正确识别的那样。这使您可以安排任务以及您希望它发生的窗口。使用它可以让操作系统为您优化任务安排以及其他应用程序的作业。例如,不是 6 个应用程序都每 10 分钟唤醒一次设备以完成他们的每小时任务,而是可以安排为所有 6 个应用程序同时发生,从而增加在打盹模式下花费的时间。

请注意,上面的屏幕截图包含一个“JobScheduler 作业”选项卡。运行分析后,您将能够看到您的工作实际执行情况:

我以前用过Firebase JobDispatcher取得了巨大成功( tutorial I wrote ),扩展了操作系统的 JobScheduler API并且最终相似。

我看到您现在正在使用 WorkManager(Jetpack 的 JobDispatcher 版本),但是在 8 秒内,操作系统没有机会优化您的作业。是否有能力以最少几秒的时间和尽可能大的时间安排它们?


进一步改进

但是,您当前的任务调度设置可能不是根本原因。这里有一些额外的想法可以提供您需要的电池改进。运行 Battery Historian 后,它们的用处会更加明显。并找出根本原因:

  1. 考虑 wifi-only 是否是数据同步的可行默认/选项。您将体验到更好的电池使用率、更少的网络问题以及可能更高的客户满意度。

  2. 为什么笔记应用需要同步几数百 MB?您是否可以只同步已更改的笔记,而不是每次都同步整个笔记列表?

关于android - 处理和解决 "Excessive network usage (background)"的正确方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54489501/

有关android - 处理和解决 "Excessive network usage (background)"的正确方法的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  6. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  7. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  8. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  9. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  10. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

随机推荐