Difference between revisions of "Improve boot performance (简体中文)"

From ArchWiki
Jump to: navigation, search
(使用systemd-analyze)
(使用 systemd-analyze)
Line 25: Line 25:
 
查看开机过程在内核/用户空间消耗的时间:
 
查看开机过程在内核/用户空间消耗的时间:
 
  $ systemd-analyze
 
  $ systemd-analyze
{{小贴士|
+
{{小贴士|如果使用 [[UEFI]] 引导,且启动引导器实现了 systemd 的 [http://www.freedesktop.org/wiki/Software/systemd/BootLoaderInterface Boot Loader Interface](目前只有 [[Gummiboot]] 实现了),'''systemd-analyze''' 还可以显示 EFI 固件和启动引导器自身花费的时间。}}
* 如果在 {{ic|/etc/mkinitcpio.conf}} 的 {{ic|HOOKS}} 数组添加 {{ic|timestamp}},并重新生成启动内存镜像({{ic|mkinitcpio -p linux}}),{{ic|systemd-analyze}} 还可以显示处理该启动镜像花费的时间。
+
* 如果使用 [[UEFI]] 引导,且启动引导器实现了 systemd 的 [http://www.freedesktop.org/wiki/Software/systemd/BootLoaderInterface Boot Loader Interface](目前只有 [[Gummiboot]] 实现了),'''systemd-analyze''' 还可以显示 EFI 固件和启动引导器自身花费的时间。}}
+
  
 
按照耗费时间顺序,输出启动每个单元耗费的时间:
 
按照耗费时间顺序,输出启动每个单元耗费的时间:

Revision as of 10:17, 29 November 2013

Summary help replacing me
本文介绍了数种加速系统启动的方法。
相关阅读
Arch Boot Process (简体中文)
Udev (简体中文)
Daemon (简体中文)
mkinitcpio
Maximizing Performance
Systemd
翻译状态: 本文是英文页面 Improve_Boot_Performance翻译,最后翻译时间:2012-11-04,点击这里可以查看翻译后英文页面的改动。

本文将为读者提供数种加速系统启动的方法。通过学习实践这些方法,读者不仅能改善系统性能,还能学习系统启动脚本的知识。

启动过程分析

使用 systemd-analyze

systemd 提供了一个分析启动过程的工具 —— systemd-analyze。可以用它看看哪些单元拖慢了开机过程,并据此进行优化。

查看开机过程在内核/用户空间消耗的时间:

$ systemd-analyze
小贴士: 如果使用 UEFI 引导,且启动引导器实现了 systemd 的 Boot Loader Interface(目前只有 Gummiboot 实现了),systemd-analyze 还可以显示 EFI 固件和启动引导器自身花费的时间。

按照耗费时间顺序,输出启动每个单元耗费的时间:

$ systemd-analyze blame

生成类似于 bootchart 的开机过程图表:

$ systemd-analyze plot > plot.svg

使用 systemd-bootchart

自2012年10月17日,bootchart 工具已经合并进 systemd 中,使用方法和原来的 bootchart 大同小异,添加下列内容到内核参数即可:

initcall_debug printk.time=y init=/usr/lib/systemd/systemd-bootchart

使用 bootchart2

由于没有办法在内核参数设置两个 init,所以不能使用源里的 bootchart。不过,AUR 软件包 bootchart2-gitAUR 提供了一个的 systemd 服务,这样就可以和 systemd 一起使用。安装后启用即可:

# systemctl enable bootchart.service

详情参阅 bootchart 文档

预读

systemd 自己实现了一个 readahead,可以用来提高开机效率。不过,效果会因内核版本和硬件情况而不同(极少数情况下还会变慢)。开启 readahead:

# systemctl enable systemd-readahead-collect.service systemd-readahead-replay.service

要知道,readahead 的超级牛力只有在重启几次后才会显现。

自己编译内核

自己编译内核、关闭不需要的功能,恐怕是加速系统启动的最有效方法了。 更多信息参见:Kernel_Compilation_From_Source

Early start for services

One central feature of systemd is D-Bus and socket activation. This causes services to be started when they are first accessed and is generally a good thing. However, if you know that a service (like UPower) will always be started during boot, then the overall boot time might be reduced by starting it as early as possible. This can be achieved (if the service file is set up for it, which in most cases it is) by issuing:

# systemctl enable upower

This will cause systemd to start UPower as soon as possible, without causing races with the socket or D-Bus activation.

Staggered spin-up

有些硬件使用staggered spin-up,操作系统一个一个访问硬盘,以减少耗电。这会降低启动速度,大部分用户都不需要开启。检查是否开启:

$ dmesg | grep SSS

如果没有查到,表示未启动。如果有显示,可以将libahci.ignore_sss=1 加入 kernel line 进行禁用。

避免重复挂载

mkinitcpio提供了 fsck 钩子,将启动加载配置中的 root 从 ro 修改为 rw 并删除 /etc/fstab 中的 root 挂载,可以避免重复挂载。挂载参数可以通过rootflags=[mount options...]设置。

删除 /etc/fstab 中的 API 文件系统,systemd 会自动挂载它们。下面命令可以获得这些 API 文件系统的列表:

$ pacman -Ql systemd | grep '\.mount$'

/home等其他文件系统可以通过自定义挂载单元进行挂载。

精简输出信息

修改启动加载器内核参数中的 verbosequiet 即可。对于某些用户,特别是 SSD 用户,TTY 的龟速实际上成为了性能瓶颈,精简输出信息实际上有利于提高性能。

参阅