ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

linux 系统启动时间调优

2020-12-02 00:00:33  阅读:392  来源: 互联网

标签:引导 systemd 系统启动 target 启动 system 调优 linux analyze


目录

背景

Systemd结构概览

系统引导性能分析

操作系统启动过程分析

1 system-analyze(内核载入开始)  

2 system-analyze blame 

3  systemctl disable 优化开机时间

4  关于systemd-analyze的补充

5  dmesg查看系统启动(操作系统上电开始)

参考文档


背景

     linux操作系统项目启动时间调优。

Systemd结构概览

让我们看一下Linux系统在使用systemd作为引导程序时的开机启动过程的结构性细节。为了简单,我们将在下面按步骤列出来这个过程:

1. 当你打开电源后电脑所做的第一件事情就是BIOS初始化。BIOS会读取引导设备设定,定位并传递系统控制权给MBR(假设硬盘是第一引导设备)。

2. MBR从Grub或LILO引导程序读取相关信息并初始化内核。接下来将由Grub或LILO继续引导系统。如果你在grub配置文件里指定了systemd作为引导管理程序,之后的引导过程将由systemd完成。Systemd使用“target”来处理引导和服务管理过程。这些systemd里的“target”文件被用于分组不同的引导单元以及启动同步进程。

3. systemd执行的第一个目标是default.target。但实际上default.target是指向graphical.target的软链接。Linux里的软链接用起来和Windows下的快捷方式一样。文件Graphical.target的实际位置是/usr/lib/systemd/system/graphical.target。在下面的截图里显示了graphical.target文件的内容。

4. 在这个阶段,会启动multi-user.target而这个target将自己的子单元放在目录“/etc/systemd/system/multi-user.target.wants”里。这个target为多用户支持设定系统环境。非root用户会在这个阶段的引导过程中启用。防火墙相关的服务也会在这个阶段启动

"multi-user.target"会将控制权交给另一层“basic.target”。

5. "basic.target"单元用于启动普通服务特别是图形管理服务。它通过/etc/systemd/system/basic.target.wants目录来决定哪些服务会被启动,basic.target之后将控制权交给sysinit.target.

6. "sysinit.target"会启动重要的系统服务例如系统挂载,内存交换空间和设备,内核补充选项等等。sysinit.target在启动过程中会传递给local-fs.target。这个target单元的内容如下面截图里所展示。

7. local-fs.target,这个target单元不会启动用户相关的服务,它只处理底层核心服务。这个target会根据/etc/fstab和/etc/inittab来执行相关操作。

系统引导性能分析

      Systemd提供了工具用于识别和定位引导相关的问题或性能影响。Systemd-analyze是一个内建的命令,可以用来检测引导过程。你可以找出在启动过程中出错的单元,然后跟踪并改正引导组件的问题。

在下面列出一些常用的systemd-analyze命令。

systemd-analyze time 用于显示内核和普通用户空间启动时所花的时间。

  1. $ systemd-analyze time
  2. Startup finished in 1440ms (kernel) + 3444ms (userspace)

systemd-analyze blame 会列出所有正在运行的单元,按从初始化开始到当前所花的时间排序,通过这种方式你就知道哪些服务在引导过程中要花较长时间来启动。

  1. $ systemd-analyze blame
  2. 2001ms mysqld.service
  3. 234ms httpd.service
  4. 191ms vmms.service

systemd-analyze verify 显示在所有系统单元中是否有语法错误。

systemd-analyze plot 可以用来把整个引导过程写入一个SVG格式文件里。整个引导过程非常长不方便阅读,所以通过这个命令我们可以把输出写入一个文件,之后再查看和分析。下面这个命令就是做这个。

  1. systemd-analyze plot > boot.svg

操作系统启动过程分析

    1 system-analyze(内核载入开始)  

     查看内核和普通用户空间启动时所画的时间

    

    2 system-analyze blame 

    列出所有正在运行的单元,按从初始化开始到当前所花的时间排序

systemctl disable 优化开机时间

通过这种方式你就知道哪些服务在引导过程中要花较长时间来启动, 执行命令systemctl disable xxx.service,关闭服务,例:

需要根据实际情况,考虑禁用占用时间较多的服务,不可随意禁用所有服务。

4  关于systemd-analyze的补充

           实际对比可以看出systemd-analyze blame 列出在线服务的总时间 < systemd-analyze 内核和用户空间的时间

           由 systemd-analyze 查看时间说明

           (1) 在启动第一个用户态进程(init)之前,内核运行了多长时间; (2) 进入实际的根文件系统之后,用户空间启动完成花了多长时间;(3)在切换进入实际的根文件系统之前,initrd(initial RAM disk)运行了多长时间。

           注意, 上述时间只是简单的计算了系统启动过程中到达不同标记点的时间, 并没有计入各单元实际启动完成所花费的时间以及磁盘空闲的时间。

5  dmesg查看系统启动(操作系统上电开始)

            dmesg  命令设备故障的诊断是非常重要的。

            通过此命令即可以查看硬件检测或者驱动加载等过程中的故障信息,同时可以通过dmesg打印出的时间戳判断哪部分故障信息印象操作系统的启动过程。

            本人在调优操作系统启动时间的过程中,发现显卡驱动有驱动失败,重复加载,占用了较多启动时间的情况。

            通过更新驱动,优化了此部分操作系统启动时间。

参考文档

   https://linux.cn/article-5457-1.html

   http://www.ruanyifeng.com/blog/2016/03/systemd-tutorial-commands.html

 

标签:引导,systemd,系统启动,target,启动,system,调优,linux,analyze
来源: https://blog.csdn.net/weixin_42121713/article/details/110455507

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有