• 解决ubuntu开机变慢;删除耗时启动项


    windows+ubuntu双系统,其中ubuntu20安装在机械硬盘上。

    使用一段时间后ubuntu20的开机时间变的很长,需要2分钟左右,而且开机后一段时间很卡顿。

    经过本文解决后开机时间从2min减少到36s。

    目录

    1、过多开机启动项

    2、snapd耗时

    3、太多journal


    1、过多开机启动项

    可以用以下命令来查看开机启动项耗时,并且关掉不需要的启动项。

    1. systemd-analyze blame #查看开机启动项耗时
    2. systemd-analyze time #查看总的开机时间
    3. systemd-analyze critical-chain #启动时间树状图
    4. systemd-analyze plot > ~/SystemdAnalyzePlot.svg #生成开机时间分析图,可以用图片或者浏览器打开看
    5. systemctl disable 启动项名称.service #禁用该启动项
    6. systemctl mask 启动项名称.service #强力禁用该启动项,确保其他项也不能唤起它

    建议删掉的开机启动服务:

    1. #网卡相关?
    2. sudo systemctl disable NetworkManager-dispatcher.service
    3. #服务器网络相关?等待网络连接
    4. sudo systemctl disable NetworkManager-wait-online.service
    5. #开机启动动画?
    6. sudo systemctl mask plymouth-quit-wait.service

    不能删掉的开机启动服务:

    1. accounts-daemon.service #账户守护进程?
    2. NetworkManager.service #删掉后桌面右上方就不会有网络的图标了
    3. systemd-journal-flush.service #boot时日志的读取和记录,不要禁用;下文会讲怎么处理
    4. snapd.service #ubuntu自带的应用管理软件,下文会讲怎么处理
    5. udisks2.service #没禁用过
    6. dev-sda3.device #后缀是device的都不要禁用,是读取硬盘

    验证某项sevice能否关闭,可以关一下看一下:

    1. #用systemctl
    2. sudo systemctl stop NetworkManager.service #暂停
    3. sudo systemctl start NetworkManager.service #启动
    4. sudo systemctl restart NetworkManager.service #重启
    5. sudo systemctl disable NetworkManager.service #禁用
    6. sudo systemctl reenable NetworkManager.service #取消禁用
    7. #也可以用service
    8. sudo service network-manager stop/start/restart/status

    2、snapd耗时

    如果你发现snapd.service耗时大,同时有一堆的dev-loop*.device耗时,那说明是snap拖慢了开机时间。如下图:

    snap其实就是ubuntu自带的软件商店software store,也叫snap-store。除了用apt或者下载deb包来安装软件外,ubuntu上还可以在这个snap软件商店里直接搜索和下载软件,我就用它下载了好几款软件(vscode、typora、SmpleScreenRecorder等)。snap也可以在命令行使用,有点类似apt-get或者apt。

    用snap包的好处就是它解决了应用程序之间的依赖问题,使应用程序之间更容易管理。但是由此带来的问题就是它占用更多的磁盘空间和boot时间,也会占用cpu等资源使得应用启动变慢。可以查看snap下安装了哪些应用:

    snap list

    可见我就用snap安装了core、code、snapd、typora等显著增加开机时间的应用。 那些dev-loop*.device磁盘空间就是snap为不同应用创建的,可以用df命令来查看磁盘的划分:

    df -h

     比如/dev/loop1和2就对应了code(vscode),那么对应的开机项dev-loop1.device和dev-loop2.device就显著增加了开机时间。

    最好的解决办法就是删除snapd。注意用snap安装的软件如vscode等也会被删除,之后用apt或者deb包重新安装一下就行(实测用deb包安装的vscode和typora软件启动都变快了)。

    1. #彻底删除snapd和配置文件
    2. sudo apt purge snapd
    3. #不要用autoremove!否则很多依赖也都会被删除
    4. #sudo apt autoremove --purge snapd

    然后你就会发现df磁盘空间里没了那些/dev/loop*项,开机也没了snapd.service和dev-loop*.device项,节约了大量开机时间。

    3、太多journal

    如果启动时systemd-journal-flush.service耗时较多,不要禁用这个服务,而应该去检查/var/log/journal文件夹是否已经积累了很多日志。每次开机boot时会把日志存在这里,并且读取以前的日志,久而久之这个文件夹越来越大,boot时耗时也越来越多了。

    可以试着删除journal文件夹:

    1. # 查看占据磁盘大小
    2. journalctl --disk-usage
    3. # 清除一些磁盘上的老的文件
    4. sudo rm -rf /var/log/journal/

    为了避免每次都手动删除日志,可以设置journal的最大容量:

    sudo gedit /etc/systemd/journald.conf

    将文件里的如下两行取消注释并添加大小限制:

    1. #SystemMaxUse=
    2. #SystemMaxFileSize=
    3. #SystemMaxFiles=
    4. SystemMaxFileSize=1G
    5. SystemMaxFiles=5
    6. #SystemMaxUse=50M #这行没试

    补充一下,/var/cache/apt下的缓存也可以清理来节约磁盘空间(但是和开机速度无关)。

    1. #删除 /var/cache/apt/archives/ 已经过期的deb.
    2. sudo apt autoclean
    3. #将 /var/cache/apt/archives/ 的 所有 deb 删掉
    4. sudo apt clean

    经过以上操作,开机时间由2min降低到了36s。现在的开机启动项和开机时间如下:

  • 相关阅读:
    用巴特沃斯滤波器对原始信号进行滤波
    在Ubuntu 20.04 LTS Focal Fossa上安装Cockpit
    pytest的搜索路径和导入模式
    ROS一键安装
    【计算机网络】什么是http?
    通过Docker新建并使用MySQL数据库
    BGP学习笔记
    项目实战(SpringJDBC框架事务管理)
    Xshell连接显示“服务器发送了一个意外的数据包。received:3,expected:20“问题
    从入门到入土的Vue2+webpack
  • 原文地址:https://blog.csdn.net/benchuspx/article/details/126607868