对应用启动的优化措施

简介: 学习笔记

对于应用启动到底合不合格,除了固定的指标之外,还有一点就是跟对比机之间进行测试对比,看有没有差距。如果不达标或者跟对比机有差距,那就要对应用启动进行优化。

对于性能差距的分析,需要抓取traces查看两台机器之间是否有区别。

对比

抓取traces后,不仅要跟对比机进行对比,也要跟正常的traces进行对比,发现是哪个环节出了问题,究竟是哪一个流程比正常的慢。

Running State

对于正在运行的CPU,我们要从以下几个维度去分析

  • CPU的频率是否正常,有没有添加限制或者跟对比机相同。
  • CPU的架构跟对比机是否一样,有的CPU会因为架构的原因对机器本身的性能产生了限制,例如KI7的A88CPU是6小核2大核,它在其他所有条件都相同的情况下一定跑不过4大核4小核的机器。
  • 如果CPU性能和架构都差不多,那就要看CPU上是否任务过重,把有些优先级没那么重要的线程延后或者放到小核去做。
  • DDR频率是否一样
  • Android版本的差距

企业微信截图_16680515616760.png

如上图所示,这是淘宝启动的时候CPU的变化,频率在启动的时候直接被拉满,并且淘宝有关的线程大多都放在了大核上去做。


Runnable State

可运行的CPU上面,我们可以看这几个差距

  • 首先看线程的设定,有没有被其他线程抢占优先级,可以先对线程优先级进行调整
  • 可以查看有没有其他较为空闲的CPU,如果有的话可以调整上去
  • 如果还是不行,就要查看CPU有没有异常背景导致任务过重找问题优化线程


CPU Loading计算: Totals time/(Selection extent time*Online CPU Number)*100%

如果CPU Loading>85%,基本确认有loading 重的嫌疑


在了解了这些后,优化应用启动的时间主要依据下面几点

  1. 提高CPU频率
  2. 提高DDR频率
  3. 拉长CPU和DDR提频时长
  4. 在可以减少动画播放的地方关闭动画
  5. 在应用安装的时候进行预编译,减少启动时长
  6. 在app白名单内专门进行配置
  7. 将启动时用到的线程跑在大核
  8. 在启动时尽量不使用网络IO


冷启动与热启动

冷启动耗时统计

adb 命令统计

adb命令 : adb shell am start -S -W 包名/启动类的全限定名 , -S 表示重启当前应用

image2022-11-16_22-34-39.png

  1. 在第①个时间段内,AMS 创建 ActivityRecord 记录块和选择合理的 Task、将当前Resume 的
    Activity 进行 pause.
  2. 在第②个时间段内,启动进程、调用无界面 Activity 的 onCreate() 等、 pause/finish 无界面的
    Activity.
  3. 在第③个时间段内,调用有界面 Activity 的 onCreate、onResum


如果需要统计从点击桌面图标到 Activity 启动完毕,可以用WaitTime作为标准。

相关文章
|
30天前
|
存储 监控 安全
服务器维护是确保服务器稳定运行、数据安全和性能优化的重要过程
【10月更文挑战第4天】服务器维护是确保服务器稳定运行、数据安全和性能优化的重要过程
121 65
|
3月前
|
运维 监控 Devops
运维自动化:提升效率与减少人为错误的策略
【8月更文挑战第12天】在信息技术的海洋中,运维自动化如同一艘装备精良的航船,引领企业驶向高效、精准的彼岸。本文将深入探讨运维自动化的重要性,分析其如何通过智能化工具和策略,实现流程优化、效率提升及错误率降低。我们将一同见证,当创新技术与运维实践相结合时,是如何为企业带来革命性变革的。
|
3月前
|
监控 Kubernetes 持续交付
持续部署的内涵和实施路径问题之确保持续部署的准确性和可预期性的问题如何解决
持续部署的内涵和实施路径问题之确保持续部署的准确性和可预期性的问题如何解决
|
4月前
|
运维 持续交付
运维自动化:提升效率与减少人为错误的关键策略
本文深入探讨了运维自动化在现代IT管理中的核心角色,从技术演进的角度分析了自动化工具的发展,并结合具体案例和统计数据,展示了自动化如何显著提高运维效率与准确性。文章还对运维自动化实施过程中的挑战进行了讨论,并提出了相应的解决策略,以期为企业实现运维自动化提供实用的指导。
|
运维 安全 数据库
渗透攻击实例-系统/服务运维配置不当
渗透攻击实例-系统/服务运维配置不当
|
SQL 存储 JavaScript
常见系统质量安全性问题相关解决方法
1. SQL注入文件写入(需要用户验证) 解决办法:通过建立过滤器方法,对所有用户输入信息进行清理过滤。通过清理过滤用户输入所包含的危险字符,便可能防止恶意的用户导致应用程序执行计划外的任务,例如:启动任意 SQL 查询、嵌入将在客户端执行的Javascript代码、运行各种操作系统命令等。
379 0
|
运维 监控 网络协议
如何监控IT正常运行时间,网络正常运行对企业业务至关重要
随着企业的扩展,其IT网络规模也将不断增长。当将大量属于不同类别,由不同供应商制造的设备添加到您的IT基础结构中时,正常运行时间的管理复杂性就急剧上升
143 0
如何监控IT正常运行时间,网络正常运行对企业业务至关重要
|
存储 SQL 安全
如何应对PHP应用的安全问题?如何处理安全漏洞?底层原理是什么?
如何应对PHP应用的安全问题?如何处理安全漏洞?底层原理是什么?
165 0
|
安全 程序员 数据库
可控参数带来的网站漏洞修复建议方案
网站中存在的越权漏洞,首先我们来讲一下什么是关键可控参数,也就是说像我们的一些关键参数,例如use ID order by ID就是一些关键的参数,必须是你的这么一个测试者,是能够去对其控制的。如果这个参数已经挟持了,或者说他有固定的这个值。那此时的话就不称为可控参数了。而关键就是你的改动必须能造成这个越权效果的一种称为关键参数。我们一定要快速定位到这种关键可控的这个参数之后,我们才能够更快速的去找到对应的这么一个越权漏洞。
182 0
可控参数带来的网站漏洞修复建议方案
|
SQL 安全 测试技术
网站漏洞渗透检测过程与修复方案
网站的渗透测试简单来 说就是模拟攻击者的手法以及攻击手段去测试网站的漏洞,对网站进行渗透攻击测试,对网站的代码漏洞进行挖掘,上传脚本文件获取网站的控 制权,并对测试出来的漏洞以及整体的网站检测出具详细的渗透测试安全报告。
262 0
网站漏洞渗透检测过程与修复方案