嵌入式 Linux 启动时间优化 1 简介 本章包含的话题有启动时间的测量、分析、人因工程(human factors)、初始化技术和优化技巧等
产品花在启动方面的时间直接影响终端用户对该产品的第一印象
一个消费电子设备不管如何引人注目或者设计得怎么好,设备从关机状态到可交互的使用状态所需的时间对于获得正面的用户体验尤为关键
案例 #1 就是在关机状态从头启动一个设备的例子
启动一个设备涉及到许多步骤和一系列的事件
为了使用前后一致的术语,消费电子 Linux 论坛(CE Linux Forum)的启动时间优化工作组起草了一个术语词汇表,该表包括了相关术语在该领域内通用的定义
该词汇表如下: 启动时间相关的词汇表 2 技术/项目主页 下面主要介绍与减少 Linux 启动时间有关的各种技术
有一部分描述了 eLinux
org 上可以下载的本地补丁,而其余部分则介绍了在其他地方维护的项目或者补丁
1 测量启动时间 Printk Times – 用于显示每个 printk 的执行时间 内核函数跟踪(Ftrace) – 用于报告内核中每个函数的调用时间 Linux 跟踪工具箱(LTT) – 用于报告确切的内核和进程事件的时间数据 Oprofile(译注:最新替代品是 perf) – 通用的 Linux 分析器(Profile) Bootchart – 用于 Linux 启动过程的性能分析和数据展示
收集启动过程中的用户空间部分的资源使用情况和进程信息,然后渲染成 PNG、SVG 或者 EPS 格式的图表
Bootprobe – 一组用于分析系统启动过程的 System Tap 脚本 当然,别忘了 cat /proc/uptime (译注:统计系统已经运行的时间) grabserial – Tim Bird (译注:CE Linux Forum 主席)写的一个非常赞