导读
通常情况下,常规用途的Linux发行版在开机启动时拉起各类相关服务进程linux 开机 启动,包括许多你可能无需使用的服务,比如蓝牙、Avahi、调制译码管理器、ppp-dns(LCTT评注:此处作者疏漏ppp-dns应当为pppd-dns)等服务进程,这种都是哪些东西?用于那里,有何功能?
Systemd提供了许多挺好的工具用于查看系统启动情况,也可以控制在系统启动时运行哪些。在这篇文章中,我将说明在Systemd类发行版中怎样关掉一些令人反感的进程。
查看开机启动项
在过去linux查看进程,你能很容易通过查看/etc/init.d了解到什么服务进程会在引导时启动。Systemd以不同的形式诠释,你可以使用如下命令列举容许开机启动的服务进程。
$ systemctl list-unit-files --type=service | grep enabled accounts-daemon.service enabled anacron-resume.service enabled anacron.service enabled bluetooth.service enabled brltty.service enabled [...]
在此列表底部,对我来说,蓝牙服务是冗余项,由于在该笔记本上我不须要使用蓝牙功能,故无需运行此服务。下边的命令将停止该服务进程linux 开机 启动,而且使其开机不启动。
$ sudo systemctl stop bluetooth.service $ sudo systemctl disable bluetooth.service
你可以通过下边命令确定是否操作成功。
$ systemctl status bluetooth.service bluetooth.service - Bluetooth service Loaded: loaded (/lib/systemd/system/bluetooth.service; disabled; vendor preset: enabled) Active: inactive (dead) Docs: man:bluetoothd(8)
停用的服务进程依旧才能被另外一个服务进程启动。假如你真的想在任何情况下系统启动时都不启动该进程,无需卸载该它,只须要把它掩藏上去就可以制止该进程在任何情况下开机启动。
$ sudo systemctl mask bluetooth.service Created symlink from /etc/systemd/system/bluetooth.service to /dev/null.
一旦你对禁用该进程启动而没有出现负面作用倍感满意,你也可以选择卸载该程序。
通过执行命令可以获得如下服务列表:
$ systemctl list-unit-files --type=service UNIT FILE STATE accounts-daemon.service enabled acpid.service disabled alsa-restore.service static alsa-utils.service masked
你不能启用或禁用静态服务,由于静态服务被其他的进程所依赖,并不意味着它们自己运行。
什么服务才能严禁?
怎么晓得你须要什么服务,而什么又是可以安全地禁用的呢?它总是依赖于你的个性化需求。
这儿举例了几个服务进程的作用。许多服务进程都是发行版特定的,所以你应当瞧瞧你的发行版文档(例如通过google或StackOverflow)。
系统启动时发生了哪些?
Systemd提供了一些命令帮助调试系统开机启动问题。该命令会重演你的系统启动的所有消息。
$ journalctl -b -- Logs begin at Mon 2016-05-09 06:18:11 PDT, end at Mon 2016-05-09 10:17:01 PDT. -- May 16 06:18:11 studio systemd-journal[289]: Runtime journal (/run/log/journal/) is currently using 8.0M. Maximum allowed usage is set to 157.2M. Leaving at least 235.9M free (of currently available 1.5G of space). Enforced usage limit is thus 157.2M. [...]
通过命令journalctl-b-1可以复审前一次启动,journalctl-b-2可以复审倒数第2次启动,以这种推。
该命令会复印出大量的信息,你可能并不关注所有信息,只是关注其中问题相关部份。因此,系统提供了几个过滤器,用于帮助你锁定目标。让我们以进程号为1的进程为例,该进程是所有其它进程的父进程。
$ journalctl _PID=1 May 08 06:18:17 studio systemd[1]: Starting LSB: Raise network interfaces.... May 08 06:18:17 studio systemd[1]: Started LSB: Raise network interfaces.. May 08 06:18:17 studio systemd[1]: Reached target System Initialization. May 08 06:18:17 studio systemd[1]: Started CUPS Scheduler. May 08 06:18:17 studio systemd[1]: Listening on D-Bus System Message Bus Socket May 08 06:18:17 studio systemd[1]: Listening on CUPS Scheduler. [...]
这种复印消息显示了哪些被启动linux 下载,或则是正在尝试启动。
一个最有用的命令工具之一systemd-analyzeblame,用于帮助查看那个服务进程启动历时最长。
$ systemd-analyze blame 8.708s gpu-manager.service 8.002s NetworkManager-wait-online.service 5.791s mysql.service 2.975s dev-sda3.device 1.810s alsa-restore.service 1.806s systemd-logind.service 1.803s irqbalance.service 1.800s lm-sensors.service 1.800s grub-common.service
这个特定的事例没有出现任何异常,而且假如存在系统启动困局,则该命令将能发觉它。
你也能通过如下资源了解Systemd怎么工作:
理解和使用Systemd
介绍Systemd运行级别和服务管理命令
再度前行,另一个Linux初始化系统:Systemd介绍
via:
作者:DavidBoth译者:penghuster校对:wxy
本文由LCTT原创编译,Linux中国荣誉推出
原文来自: