Linux 启动时间优化实战,2.41 秒启动应用!

劳动节快乐,祝大家都能有所收获!

今天我参加了一个关于启动优化的讲座,这里简要总结一下。

本文旨在分享一些简单有效的优化方法,并不涵盖所有技巧。有兴趣的朋友可以关注我的视频号,后续我会通过直播与大家进一步交流。

Linux 启动时间优化实战,2.41 秒启动应用!目标系统

硬件:

Beagle Bone Black (Cortex A8)

USB 摄像头 + LCD

软件:

Linux 5.1 + Buildroot rootfs

FFmpeg,用于采集视频并解码到 LCD。

Linux 启动时间优化实战,2.41 秒启动应用!点击查看大图

当前启动时间:

从上电到 LCD 显示第一帧图像:9.45 秒

1、优化编译器ARM vs Thumb2

比较基于 ARM 或 Thumb2 指令集编译的系统和应用。

ARM:rootfs 为 3.79 MB,ffmpeg 为 227 KB。

Thumb2:3.10 MB (-18%),183 KB (-19%)。

性能方面:Thumb2 的性能略有提升(约小于 5%)。

尽管性能有所提升,我个人还是倾向于选择 ARM 指令集。

musl vs uClibc

Buildroot 中有三种 C 库可选:glibc、musl、uClibc,我们只比较后两种较小的库。

musl:680 KB (统计 /lib 目录)。

uClibc:570 KB (-16%)。

uClibc 节省了 110 KB,我们选择 uClibc。

2、优化应用程序我们可以通过 ./configure 对 FFmpeg 的功能组件进行选择。

此外,还可以使用 strace 和 perf 命令调试以优化 FFmpeg 的内部代码。

优化后的结果:

文件系统:从 16.11 MB 缩小到 3.54 MB (-78%)。

程序的加载和运行时间:缩短 150 ms。

整体启动时间:缩短 350 ms。

虽然空间优化效果显著,但在启动时间上的优化较小,这是因为 Linux 在运行程序时只加载程序的必要部分。

3、优化 Init 和根文件系统思路:

使用 bootchartd 分析系统启动并裁剪不必要的服务。

将 /etc/init.d/ 下的启动脚本合并为一个。

不挂载 /proc 和 /sys。

裁剪 BusyBox,文件系统越小,内核挂载可能会越快。

将 Init 程序替换为我们的应用程序。

静态编译应用程序。

裁剪掉不常用的文件,找出长时间不访问的文件:

$ find / -atime -1000 -type f

优化后的结果:

文件系统:裁剪 Busybox 后,从 3.54 MB 缩小到 2.33 MB (-34%)。

启动时间:基本没有变化,大概是因为文件系统本身已经足够小了。

使用 initramfs 作为 rootfs:

通常情况下,Linux 系统会先挂载 initramfs,initramfs 很小且位于内存中,再由 initramfs 负责负载根文件系统。

当我们将 Buildroot rootfs 裁剪得很小时,就可以考虑直接将其作为 initramfs 使用。

这样有什么好处呢?

initramfs 可以和 Kernel 拼接在一起,Bootloader 负责将 Kernel+initramfs 加载到内存中,内核不再需要访问磁盘。

内核不再需要 block/storage 和 filesystem 相关的功能,体积会变得更小,加载时间和初始化时间都会变小。

注意,需要关闭 initramfs 的压缩(CONFIG_INITRAMFS_COMPRESSION_NONE)。

优化后的结果:

即便禁用了 CONFIG_BLOCK 和 CONFIG_MMC 后,总启动时间仍增加了 20ms。这可能是因为 Kernel + initramfs 拼在一起之后,内核变大了许多,而内核镜像是需要解压,解压的时间增多了。

4、优化内核评估方法:

在启动参数中添加 initcall_debug,可以获得更多内核 log:

[ 3.750000] calling ov2640_i2c_driver_init+0x0/0x10 @ 1[ 3.760000] initcall ov2640_i2c_driver_init+0x0/0x10 returned 0 after 544 usecs[ 3.760000] calling at91sam9x5_video_init+0x0/0x14 @ 1[ 3.760000] at91sam9x5-video f0030340.lcdheo1: video device registered @ 0xe0d3e340, irq = 24[ 3.770000] initcall at91sam9x5_video_init+0x0/0x14 returned 0 after 10388 usecs[ 3.770000] calling gspca_init+0x0/0x18 @ 1[ 3.770000] gspca_main: v2.14.0 registered[ 3.770000] initcall gspca_init+0x0/0x18 returned 0 after 3966 usecs...

此外,可以使用 scripts/bootgraph.pl 将 dmesg 的信息转换成图片:

$ scripts/bootgraph.pl boot.log > boot.svg

Linux 启动时间优化实战,2.41 秒启动应用!点击查看大图

接下来,找出消耗时间最多的环节,进行优化。

裁掉 tracing

在 Kernel hacking 中关闭 Tracers 相关的功能。

启动时间:缩短 550ms。

秒哒 秒哒

秒哒-不用代码就能实现任意想法

秒哒 134 查看详情 秒哒

内核大小:缩小 217KB。

裁掉一些用不上的硬件功能

omap8250_platform_driver_init() // (660 ms)cpsw_driver_init()  // (112 ms)am335x_child_init() // (82 ms)...

预设 loops per jiffy

在每次启动时,内核都会校准 delay loop 的值,用于 udelay() 函数。

这会测量 loops per jiffy (lpj) 的值。我们只需要启动一次内核,在 log 中查找 lpj 值:

Calibrating delay loop... 996.14 BogoMIPS (lpj=4980736)

然后将 lpj=4980736 填写到启动参数中,即可:

Calibrating delay loop (skipped) preset value.. 996.14 BogoMIPS (lpj=4980736)

大约缩短了 82 ms。

禁用 CONFIG_SMP

SMP 的初始化很慢。它通常在默认配置中是启用的,即使是一个单核 CPU。

如果我们的平台是单核的,可以禁用 SMP。

关闭后,内核缩小:-188 KB (-4.6%),启动时间缩短 126ms.

禁用 log

启动参数中添加 quiet,启动时间缩短 577 ms。

禁用 CONFIG_PRINTK 和 CONFIG_BUG 后,内核缩小 118 KB (-5.8%)。

禁用 CONFIG_KALLSYMS 后,内核缩小 107 KB (-5.7%)。

合计,启动时间缩短 767 ms。

开启 CONFIG_EMBEDDED 和 CONFIG_EXPERT

这会让系统调用变得更精简,内核会变得没那么通用,但是能保持你的应用程序能运行就足够了。

内核缩小 51 KB。

启动时间缩短 34 ms。

选择 SLAB memory allocators

一般是 SLAB、SLOB、SLUB 三选一。

SLAB:默认选择,最通用、最传统、最可靠。

SLOB:更简洁,代码量更少,更节省空间,适合嵌入式系统,使能后,内核缩小 5 KB,但是启动时间增加 1.43 S!

SLUB:更合适大型系统,使能后,启动时间增加 2 ms。

因此,我们仍使用 SLAB。

内核压缩方式

不同压缩方式的特点如下:

Linux 启动时间优化实战,2.41 秒启动应用!实测效果:

Linux 启动时间优化实战,2.41 秒启动应用!看起来,gzip 和 lzo 表现更好。测试的效果应该是和 CPU/磁盘 的性能相关的。

内核编译参数

使能 CONFIG_CC_OPTIMIZE_FOR_SIZE,该选项可能是用 gcc -Os 代替 gcc -O2。

Linux 启动时间优化实战,2.41 秒启动应用!点击查看大图

注意,这只是在 BeagleBone Black + Linux 5.1 上的测试结果,不同平台之间有差异。

禁用 /proc 等伪文件系统

要考虑应用的兼容性。

ffmpeg 依赖 /proc,所以只能关闭一些 proc 相关的选项:CONFIG_PROC_SYSCTL、CONFIG_PROC_PAGE_MONITOR CONFIG_CONFIGFS_FS,启动时间没有变化。

关闭 sysfs,启动时间缩短 35 ms。

拼接 DTB

启用 CONFIG_ARM_APPENDED_DTB:

$ cat arch/arm/boot/zImage arch/arm/boot/dts/am335x-boneblack-lcd4.dtb > zImage$ setenv bootcmd 'fatload mmc 0:1 81000000 zImage; bootz 81000000'

启动时间缩短 26 ms。

5、优化 Bootloader这里我们采用最好的方案:使用 Uboot Falcon mode。

Falcon mode 只执行 Uboot 的第一阶段:SPL,然后跳过 Stage 2,执行加载 Kernel。

启动时间缩短 250 ms。

总结到此,启动优化基本完成,最终效果如下:

[0.000000 0.000000][0.000785 0.000785] U-Boot SPL 2019.01 (Oct 27 2019 - 08:04:06 +0100)[0.057822 0.057822] Trying to boot from MMC1[0.378878 0.321056] fdt_root: FDT_ERR_BADMAGIC[0.775306 0.396428] Waiting for /dev/video0 to be ready...[1.966367 1.191061] Starting ffmpeg...[2.412284 0.004277] First frame decoded

从上电到 LCD 显示第一帧图像,总时间为 2.41 秒。

最有效果的步骤如下:

Linux 启动时间优化实战,2.41 秒启动应用!点击查看大图

仍值得优化的空间:

系统花了 1.2 秒等待 USB 摄像头的枚举,这里是否有办法加速?

是否可以关闭 tty 和终端登录?

最后,关于优化启动时间,有一些原则可以遵循:

请不要过早地进行优化。

从一些影响面最小的点开始优化。

从 rootfs、kernel、bootloader 自上而下进行优化。

重点关注短板。

感谢阅读,欢迎转发哦!

以上就是Linux 启动时间优化实战,2.41 秒启动应用!的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/465655.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 05:19:43
下一篇 2025年11月8日 05:23:14

相关推荐

  • 定投收益缩水!以太坊质押APY降至3.6%的应对策略

    近期以太坊质押的年化收益率(APY)降至约3.6%,这让许多寻求稳定收益的参与者感到收益缩水。本文将详细阐述一种结合了定投(DCA)和流动性挖矿的组合策略,旨在应对单一质押收益下降的问题。通过讲解这套组合策略的操作过程,为您提供一个优化“躺赚”收益的参考方案。 2025以太坊交易平台官网注册地址推荐…

    2025年12月8日 好文分享
    000
  • 2025年MEME币交易主战场:热门平台交易量排行榜

    进入2025年,加密货币市场展现出与以往截然不同的活力,其中MEME币板块的崛起尤为引人注目。这些源于互联网文化、由社区驱动的数字资产,已经从边缘化的玩笑演变为一股不可忽视的金融力量。它们不再仅仅是投机者的乐园,更成为了衡量市场情绪和散户参与度的重要指标。强大的社区共识和病毒式的社交媒体传播,是ME…

    2025年12月8日 好文分享
    000
  • 新兴SAHARA交易所评测_2025年SAHARA潜力黑马平台

    一键直达|2025主流加密资产交易所平台 Binance币安 Huobi火币 欧易OKX 2025年新兴SAHARA交易所评测——潜力黑马平台深度解析 随着SAHARA资产在市场上的持续走热,一批新兴交易所迅速崛起,凭借创新的产品设计、灵活的合规策略和差异化服务,成为投资者关注的“潜力黑马”。本文精…

    2025年12月8日
    000
  • 交易所平台可靠性参考:2025年持续高交易量App观察

    进入数字资产交易领域,选择一个可靠的平台是投资者保障资产安全与提升交易效率的关键。当前市场中,众多交易所凭借其庞大的用户基础、深厚的市场流动性以及完善的产品矩阵,构建了各自独特的竞争优势。平台的可靠性并非单一维度可以衡量,它综合了技术安全、资产储备、合规水平、用户体验等多方面因素。交易量作为一个直观…

    2025年12月8日 好文分享
    000
  • 必安安卓版安装教程 手机端Binance APP最新下载链接

    币安(binance)是全球知名的加密货币交易平台,为全球用户提供广泛的数字资产交易及相关服务。作为世界领先的数字资产交易平台,币安致力于提供安全、便捷、高效的交易体验。 官方下载地址: 币安交易所详细介绍 1. 交易品种丰富:币安提供极其丰富的数字资产交易对,涵盖了比特币(BTC)、以太坊(ETH…

    2025年12月8日
    000
  • 必安交易所APP下载 官方正版Binance安装包获取方式

    必安交易所APP下载 官方正版Binance安装包获取方式 必安交易所,是全球领先的数字资产交易平台之一,为用户提供广泛的加密货币交易及相关服务。平台以其强大的技术基础、深厚的市场流动性、多样的交易产品和严格的安全措施而闻名,服务于全球数百万用户,支持多种主流及创新型数字货币的交易。 官方下载地址:…

    2025年12月8日
    000
  • 2025年主流交易所币种丰富度与交易量排行榜

    进入2025年,全球数字资产市场呈现出高度活跃与专业化的竞争格局。交易所作为连接用户与数字资产的核心枢纽,其重要性不言而喻。衡量一家交易所综合实力的关键指标,主要集中在其币种丰富度与市场交易量上。币种的广度与深度决定了交易所能否满足不同风险偏好用户的投资需求,从主流的价值币到新兴的潜力项目,全面的资…

    2025年12月8日 好文分享
    000
  • 稳定币如何实现1:1锚定? 新手购买稳定币全攻略

    稳定币是一种加密货币,其价值被设计成与某种稳定资产(通常是法币,如美元)保持1:1的锚定关系。它们的出现,旨在结合加密货币的去中心化、无国界等特性,同时规避传统加密资产如比特币、以太坊等的价格剧烈波动性。 稳定币的锚定机制 1. 法币抵押型稳定币。 这类稳定币的价值由等值的传统法币储备支持。发行方声…

    2025年12月8日
    000
  • 币安iOS版如何安装 苹果手机Binance官方APP下载指南

    币安iOS版如何安装 苹果手机Binance官方APP下载指南 币安作为全球知名的加密货币交易平台,凭借其庞大的交易量和丰富的数字资产种类,服务于全球数千万用户。它提供一站式的加密货币交易与生态服务,是数字资产领域的重要参与者。 官方下载地址: 交易所核心特点与优势 1. 币安提供极为广泛的加密货币…

    2025年12月8日
    000
  • 2025年交易所24小时交易峰值:哪些平台市场最活跃?

    在数字资产的世界里,交易平台的活跃度是衡量其市场地位、流动性深度与用户信任度的核心标尺。24小时交易峰值,这个看似简单的数字,背后浓缩了一个平台的综合实力。它不仅反映了市场在特定时间内的热度与资金流向,更揭示了平台在资产多样性、交易引擎性能、风险控制体系以及全球用户基础等多个维度的竞争力。当巨量的买…

    2025年12月8日 好文分享
    000
  • 什么是NodeOps(NODE)?值得投资吗?NodeOps(NODE)项目全面介绍

    目录 简要事实:NodeOps(NODE)概览NodeOps 是什么?NODE 代币有多少?NODE 代币有何作用?NodeOps 的核心产品和服务NodeOps(NODE)与以太坊(ETH):两层的故事NodeOps背后的技术团队与起源NODE 是否是一项潜在的优质投资?平衡的观点潜在优势需要考虑…

    2025年12月8日 好文分享
    000
  • 被低估的加密代币:计算令牌窃取节目吗?

    计算代币因其在人工智能和分布式计算领域的潜力而逐渐受到关注,但在与gamefi及传统金融的对比中,它们是否仍被低估? 被低估的加密资产:计算代币正悄然崛起? =================== 加密市场正在升温,但并不是每种代币都获得同等的关注。尽管GameFi代币往往因其前景而被高估,但另一类…

    2025年12月8日
    000
  • Apple,Openai和Siri的AI大修:纽约的一分钟技术戏剧

    据报道,苹果公司正在与openai和anthropic展开对话,希望借助先进的ai技术对siri进行重大升级。本文将探讨这一潜在变革及其对用户可能带来的影响。 苹果正在加速追赶AI浪潮,而Siri正面临巨大的升级压力。消息称,苹果有意携手Openai与Anthropic,为Siri带来一次深度重塑。…

    2025年12月8日
    000
  • 交易平台整体规模对比:2025年交易所总交易量及用户体量排名

    进入2025年,全球数字资产市场呈现出高度分化与竞争集中的格局。交易平台作为连接用户与数字资产的核心枢纽,其重要性不言而喻。平台的规模不再仅仅由单一的交易量数据来衡量,而是综合了用户体量、资产多样性、产品深度、品牌影响力以及全球合规化布局等多重维度的复杂考量。这一年,各大交易平台在巩固自身核心优势地…

    2025年12月8日 好文分享
    000
  • BNB Chain日活破千万!DEX防夹机制碾压以太坊?

    BNB Chain近期日活用户数表现亮眼,其生态的繁荣引发广泛关注。本文主要围绕标题中“DEX防夹机制是否优于以太坊”这一问题展开,将通过深入对比PancakeSwap V4与Uniswap V4的核心机制来进行解答。文章会详细阐述两者在应对“夹子攻击”(MEV)和优化低滑点交易路径上的策略与实现过…

    2025年12月8日 好文分享
    000
  • 币圈交易平台新锐力量:2025年交易量增速显著App

    进入2025年,数字资产交易市场的竞争格局呈现出愈发激烈的态势。各大交易平台在用户体验、产品深度、资产安全与全球化合规布局等多个维度展开了全面的角力。交易量已不再是衡量一个平台实力的唯一标准,用户活跃度、资产多样性以及生态系统的构建能力,共同描绘出顶级交易所的综合画像。用户对于交易应用(App)的依…

    2025年12月8日 好文分享
    000
  • XRPL EVM Sidechain:在XRP上释放智能合约和跨链Defi

    xrpl evm sidechain现已上线!了解它如何为xrp ledger带来以太坊兼容性、智能合约功能以及一个全新的喜爱世界。 准备好你的帽子吧,朋友们!XRPL EVM Sidechain正式启动并运行,这将为XRP Ledger生态系统注入新的活力。这不是一次小更新,而是一次彻底的变革,释…

    2025年12月8日
    000
  • 稳定币 vs 加密货币,区别在哪?如何轻松购买稳定币?

    在数字资产领域,稳定币和加密货币是两类重要的存在,它们虽然都基于区块链技术,但在本质和用途上存在显著区别。理解这些差异,有助于更好地参与数字资产市场。 稳定币与加密货币的核心区别 1.  价格稳定性是主要的区分点。普通加密货币(例如比特币、以太坊)的价格波动剧烈,可能在短时间内大幅上涨或下跌。稳定币…

    2025年12月8日
    000
  • Katana Mainnet上线:十亿个Kat代币抢购!

    polygon与gsr联合推出的katana主网现已正式上线,十亿枚kat代币激励计划同步启动。准备好参与养殖和娱乐新体验了吗? Katana主网上线:十亿KAT代币奖励等你来拿! 加密世界的财富风暴又来了!业内最新消息显示,由Polygon和GSR联手打造的Katana主网已经正式启动。这不是一次…

    2025年12月8日
    000
  • Ripple诉讼,SEC,XRP价格:XRP的下一步是什么?

    分析连锁诉讼、潜在的sec行动及其对xrp价格影响的最新动态。现货xrp etf是否即将到来? “Ripple诉讼、SEC、XRP价格”的故事持续吸引着加密圈的关注。随着可能的结局临近以及高价预测频出,XRP接下来会如何走?我们来深入解读一番。 Ripple与SEC:终局将至? 有消息称,这场旷日持…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信