windows+ubuntu双系统,其中ubuntu20安装在机械硬盘上。
使用一段时间后ubuntu20的开机时间变的很长,需要2分钟左右,而且开机后一段时间很卡顿。
经过本文解决后开机时间从2min减少到36s。
目录
1、过多开机启动项
2、snapd耗时
3、太多journal
1、过多开机启动项
可以用以下命令来查看开机启动项耗时,并且关掉不需要的启动项。
systemd-analyze blame #查看开机启动项耗时
systemd-analyze time #查看总的开机时间
systemd-analyze critical-chain #启动时间树状图
systemd-analyze plot > ~/SystemdAnalyzePlot.svg #生成开机时间分析图,可以用图片或者浏览器打开看
systemctl disable 启动项名称.service #禁用该启动项
systemctl mask 启动项名称.service #强力禁用该启动项,确保其他项也不能唤起它
建议删掉的开机启动服务:
#网卡相关?
sudo systemctl disable NetworkManager-dispatcher.service
#服务器网络相关?等待网络连接
sudo systemctl disable NetworkManager-wait-online.service
#开机启动动画?
sudo systemctl mask plymouth-quit-wait.service
不能删掉的开机启动服务:
accounts-daemon.service #账户守护进程?
NetworkManager.service #删掉后桌面右上方就不会有网络的图标了
systemd-journal-flush.service #boot时日志的读取和记录,不要禁用;下文会讲怎么处理
snapd.service #ubuntu自带的应用管理软件,下文会讲怎么处理
udisks2.service #没禁用过
dev-sda3.device #后缀是device的都不要禁用,是读取硬盘
验证某项sevice能否关闭,可以关一下看一下:
#用systemctl
sudo systemctl stop NetworkManager.service #暂停
sudo systemctl start NetworkManager.service #启动
sudo systemctl restart NetworkManager.service #重启
sudo systemctl disable NetworkManager.service #禁用
sudo systemctl reenable NetworkManager.service #取消禁用
#也可以用service
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软件启动都变快了)。
#彻底删除snapd和配置文件
sudo apt purge snapd
#不要用autoremove!否则很多依赖也都会被删除
#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文件夹:
# 查看占据磁盘大小
journalctl --disk-usage
# 清除一些磁盘上的老的文件
sudo rm -rf /var/log/journal/
为了避免每次都手动删除日志,可以设置journal的最大容量:
sudo gedit /etc/systemd/journald.conf
将文件里的如下两行取消注释并添加大小限制:
#SystemMaxUse=
#SystemMaxFileSize=
#SystemMaxFiles=
SystemMaxFileSize=1G
SystemMaxFiles=5
#SystemMaxUse=50M #这行没试
补充一下,/var/cache/apt下的缓存也可以清理来节约磁盘空间(但是和开机速度无关)。
#删除 /var/cache/apt/archives/ 已经过期的deb.
sudo apt autoclean
#将 /var/cache/apt/archives/ 的 所有 deb 删掉
sudo apt clean
经过以上操作,开机时间由2min降低到了36s。现在的开机启动项和开机时间如下:文章来源:https://www.toymoban.com/news/detail-447565.html
文章来源地址https://www.toymoban.com/news/detail-447565.html
到了这里,关于解决ubuntu开机变慢;删除耗时启动项的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!