Systemd

From Gentoo Wiki
Jump to: navigation, search
This page is a translated version of the page Systemd and the translation is 95% complete.

Other languages:
English • ‎español • ‎italiano • ‎日本語 • ‎한국어 • ‎português do Brasil • ‎русский • ‎中文(中国大陆)‎

Warning: Display title "systemd/zh-cn" overrides earlier display title "Systemd".

Resources

systemd is a modern SysV-style init and rc (run command)[1] replacement for Linux systems. It is supported in Gentoo as an alternative init system.

安装

Note
If updating from <=sys-apps/systemd-203 check the upgrade sub-article.

内核

systemd使现代Linux内核的许多特色得以充分发挥。现在,要想支持systemd,内核版本必须高于ebuild 2.6.39。 在最新的版本 sys-kernel/gentoo-sources包中, 有一个快捷的方法,使得systemd成为强制选择或可选的内核选项(请看Kernel/Configuration 来获得进一步的了解):

KERNEL 快速安装使用gentoo-sources
Gentoo Linux --->
        Support for init systems, system and service managers --->
                [*] systemd

手动配置内核选项 (这是在不使用sys-kernel/gentoo-sources时,唯一的选择 ), 下面是内核配置选项的要求或建议:

KERNEL 必要选项
General setup  --->
	[*] open by fhandle syscalls
	[*] Control Group support --->
	[ ] Enable deprecated sysfs features to support old userspace tools
	[*] Configure standard kernel features (expert users)  --->
		[*] Enable eventpoll support
		[*] Enable signalfd() system call
		[*] Enable timerfd() system call
[*] Networking support --->
Device Drivers  --->
	Generic Driver Options  --->
		[*] Maintain a devtmpfs filesystem to mount at /dev
File systems  --->
	[*] Inotify support for userspace
	Pseudo filesystems  --->
		[*] /proc file system support
		[*] sysfs file system support
KERNEL 推荐选项
General setup  --->
        [*] Checkpoint/restore support
	[*] Namespaces support  --->
		[*] Network namespace
[*] Enable the block layer  --->
	[*] Block layer SG support v4
Processor type and features  --->
	[*] Enable seccomp to safely compute untrusted bytecode
Networking support --->
	Networking options --->
		<*> The IPv6 protocol
Device Drivers  --->
	Generic Driver Options  --->
		()  path to uevent helper
		[ ] Fallback user-helper invocation for firmware loading
Firmware Drivers  --->
	[*] Export DMI identification via sysfs to userspace
File systems --->
	<*> Kernel automounter version 4 support (also supports v3)
	Pseudo filesystems --->
		[*] Tmpfs virtual memory file system support (former shm fs)
		[*]   Tmpfs POSIX Access Control Lists
		[*]   Tmpfs extended attributes

UEFI系统应该启用下面的选项:

KERNEL UEFI支持
[*] Enable the block layer  --->
	Partition Types  --->
		[*] Advanced partition selection
		[*]   EFI GUID Partition support
Processor type and features  --->
	[*] EFI runtime service support
Firmware Drivers  --->
        EFI (Extensible Firmware Interface) Support -->
	        <*> EFI Variable Support via sysfs

如果你的系统使用BFQ scheduler, 这里推荐使用 BFQ upstream 来启用 "BFQ hierarchical scheduling support" 下的"Enable the block layer -> IO Schedulers".

要获取最新的列表,请参阅部分上游的“需求”说明:README文件。

/etc/mtab

上游仅支持 /etc/mtab,它是一个链接文件,链接到/proc/self/mounts。如果不建立这个链接文件,就会导致mount (bug #434090) 和 df (bug #477240) 。在之前有一些系统工具会写入信息(比如写入/etc/mtab里面的挂载选项),因此它应该是一个普通文件。现在所有的软件应该避免这个问题。不过,在转换文件成为链接文件之前,请检查 bug #477498,来确保系统不受任何已知错误报告的影响。

要创建链接文件,执行:

root #ln -sf /proc/self/mounts /etc/mtab

在启动时确保挂载了/usr路径

如果你对/usr进行单独分区,在你运行systemd前,要使用initramfs 来挂载/usr分区 。就目前而言,这直到包 sys-kernel/genkernel可用前,使用sys-kernel/dracutsys-kernel/genkernel-next ,他们支持挂载/usr 。这为的是现在进行安装:

root #emerge --ask --unmerge sys-kernel/genkernel
root #emerge --ask sys-kernel/dracut
root #emerge --ask sys-kernel/genkernel-next

当你使用dracut时,如果它不自动启用/usr模块,请手动安装。

FILE /etc/dracut/dracut.conf
# Dracut modules to add to the default
add_dracutmodules+="usrmount"

当你使用genkernel-next时,在重新编译内核之前,一定要在genkernel配置中设置UDEV 变量,使他变成yes。这将把/usr配置到initramfs中:

FILE /etc/genkernel.conf
# 使用udev而不是把MDEV作为initramfs的默认设备管理器。
#如果systemd或者同时使用LVM,那么必须开启下列选项。
UDEV="yes"
root #genkernel --install all

参考 Initramfs guide 来获得更多帮助。

使用LVM和initramfs

当使用 sys-fs/lvm2,且系统通过initramfs 启动时,必须使用sys-kernel/genkernel-next 包来创建initramfs :

root #genkernel --udev --lvm <target>

这意味着创建一个initramfs genkernel target,使用<target>initramfs 。更多有关信息,请查看genkernel --help的提示:

user $genkernel --help

当使用LVM时, 需要启动 lvmetad守护进程。否则systemd将无法挂载LVM卷。可以在/etc/lvm/lvm.conf中启用lvmetad:

FILE /etc/lvm/lvm.conflvm.conf中需要更改的部分
# Set use_lvmetad to '1' for systemd
use_lvmetad = 1
附注
这可通过lvmetad.socket组件激活lvmetad.service来获得, 而不是通过修改 /etc/lvm/lvm.conf,但当前版本的sys-fs/lvm2 还不支持这些功能。

USE flags

Cannot load package information. Is the atom sys-apps/systemd correct?

Installation

开启 systemd 在全局USE flag 中,(make.conf中)。consolekit USE flag 也应该被禁用,以防止与systemd-logind服务产生冲突。另外,也可以切换到一个systemd sub profile使用的较好的USE标记的默认值,在这种情况下,没有必要改变make.conf:

root #eselect profile list

最后,更新系统与Flags:

root #emerge -avDN @world

出现依赖性问题时(如 sys-fs/udev blocking sys-apps/systemd), sys-fs/udev,这可能是world文件已经被记录。要解决这个问题。试着取消:

sys-apps/systemd中包含 udev。一旦安装了sys-apps/systemd ,那么就可以删除 sys-fs/udev,因为systemd将会提供virtual/udev

root #emerge --deselect sys-fs/udev

Bootloader

为了运行systemd,切换init可用内核 (或者 initramfs)使用。

警告
先前被设置的服务管理器服务不会自动启动。这是因为该系统切换到不同的服务管理器。为了获得像网络或登录管理器的这样功能,这些服务需要被重新启用。更多关于这个的信息,在之后本文后面部分的‘‘‘服务’’’章节。
附注
如果在迁移启动引导器中发生了错误,它一般可以通过撤销该INIT变化这一步,来使用回默认的引导服务管理器(OpenRC)。这可以安全返回。本文的最后的故障排除章节,用来解决这些问题以便于可以安全的返回系统。

接下来的部分文档指导你如何切换init 启动管理器或内核。

GRUB Legacy (0.x)

 init=/usr/lib/systemd/systemd 这行代码参数应该被添加到内核的代码行。这是一个摘自grub.conf例子,它应该是这样:
FILE /boot/grub/grub.confGRUB systemd 配置示例
title=Gentoo with systemd
root (hd0,0)
kernel /vmlinuz root=/dev/sda2 init=/usr/lib/systemd/systemd

如果要想使用OpenRC系统启动,尝试使用 real_init 替换init

GRUB 2

grub-mkconfig 被使用时, 增加 init 这一行 GRUB_CMDLINE_LINUX:

附注
这个不需要使用一个initramfs生成dracutsystemd ,因为initramfs内部已经有了systemd。
FILE /etc/default/grubGRUB2 systemd 配置示例
# Append parameters to the linux kernel command line
GRUB_CMDLINE_LINUX="init=/usr/lib/systemd/systemd"

手动配置GRUB 2文件时(仅限有经验的用户), 添加init=参数到 linuxlinux16命令行。

FILE /boot/grub/grub.cfgGRUB2 配置示例片段
linux /vmlinuz-3.10.9 root=UUID=508868e4-54c6-4e6b-84b0-b3b28b1656b6 init=/usr/lib/systemd/systemd

当使用 genkernel-next's 引导时, 使用real_init 来替换init.

附注
real_init应该在genkernel-next稳定版中弃用。

In-kernel config

Init配置也可以在内核配置被固定。请看Processor type and features -> Built-in kernel command line. . 注意:这个方法适用于 GRUB.和 GRUB2

Configuration

systemd支持通过几个系统配置文件,来满足系统最基本的运行要求。

附注
虽然一些系统配置参数可通过修改相应的配置文件而被更新,但大部分设定使用需要systemd才能被系统设置程序管理。在这种情况下,使用systemd重新引导计算机是安全的hostnamectl, localectl, 然而系统设置timedatectl是必需的

Machine ID

创建一个ID来记录工作。这可以通过以下命令进行:

root #systemd-machine-id-setup

主机名称

要设置主机名称,创建/编辑 /etc/hostname ,然后直接输入所需的主机名。

当使用systemd启动时,一个叫 hostnamectl的工具 ,可以编辑/etc/hostname/etc/machine-info来达到目的. 要更改主机名,执行:

root #hostnamectl set-hostname <HOSTNAME>

参考 man hostnamectl 来获得更多选项。


区域设置

通常,区域设置将从OpenRC转换到安装systemd时被很好的设置。在你需要时,可以按照Gentoo手册的说明,设置语言环境/etc/locale.conf :

FILE /etc/locale.conf系统本地化配置
LANG="en_US.utf8"

如果你通过systemd启动,那么工具localectl可以被使用来设置区域在控制台或X11键盘映射的地区设置。要更改系统区域设置,请运行下列命令:

root #localectl set-locale LANG=<LOCALE>

更改虚拟控制台键盘映射表:

root #localectl set-keymap <KEYMAP>

最后,要设置X11布局:

root #localectl set-x11-keymap <LAYOUT>

如果需要model, 变量和选项也可以被指定:

root #localectl set-x11-keymap <LAYOUT> <MODEL> <VARIANT> <OPTIONS>

时间和日期

可以使用timedatectl来设置时间和日期。它也允许用户设置同步,而无需依赖net-misc/ntp 或者其他的systemd自己的工具。

学习如何使用 timedatectl 只需运行:

root #timedatectl --help

自动加载模块

自动加载模块配置在不同的文件中,或者更确切地说,在目录中的文件中。配置文件存储在/etc/modules-load.d。在启动与模块列表的每个文件将被加载,文件格式是由换行符分隔模块的列表,并且可以使用任何名称,只要它的扩展名是.conf。 加载模块可以由程序、服务或其他方式,取决于符合个人喜好。举个例子——virtualbox.conf。如下表所示:

FILE /etc/modules-load.d/virtualbox.confvirtualbox 模块示例文件
vboxdrv
vboxnetflt
vboxnetadp
vboxpci

网络

systemd-networkd系统守护进程管理网络配置

systemd-networkd在有线网络接口的,简单的配置上是很有用的。它在默认情况下是禁用的。

要配置systemd-networkd,在/etc/systemd/network路径下创建一个文件:

FILE /etc/systemd/network/50-dhcp.network
[Match]
Name=en*
 
[Network]
DHCP=yes
root #systemctl enable systemd-networkd.service
root #systemctl start systemd-networkd.service

注意systemd-networkd resolv.conf默认不会自动更新,要systemd管理DNS设置,替换resolv.conf为一个符号连接并启动到systemd-resolved。

root #ln -snf /run/systemd/resolve/resolv.conf /etc/resolv.conf
root #systemctl enable systemd-resolved.service
root #systemctl start systemd-resolved.service

网络管理

通常NetworkManager的用于配置网络设置。为了这个目的,简单地用一个基于X11的桌面时,运行以下命令:

root #nm-connection-editor

如果情况并非如此,网络需要从终端来配置,nmcli值得试试, 或者遵循配置指导nmtui

root #nmtui

nmtui 是一个ncurses的前端,在控制台模式下运行,同时将引导用户的过程中。

处理日志文件

systemd 有自己的方式处理日志文件,而不需要依赖任何外部日志系统 (像 app-admin/syslog-ngapp-admin/rsyslog)。日志信息可以通过 journalctl来读取。 但是无论如何,它仍然可以被配置为使用一个更优秀的外部工具来处理它们。 请打开终端输入man journald.conf来学习如何配置journald来满足你的个人的需求。

一些常用选项journalctl:

Command line options for journalctl Result
journalctl without options Show all log entries, starting with earliest.
-b, --boot Show all log entries from this boot.
-r, --reverse Newest entries first.
-f, --follow Show the last few entries and display new log entries as they're being produced.
-p, --priority= Specify (minimum) priority to display messages, with a choice from: "emerg" (0), "alert" (1), "crit" (2), "err" (3), "warning" (4), "notice" (5), "info" (6), "debug" (7).
--since=, --until= Restrict entries by time. Accepts the format "YYYY-MM-DD hh:mm:ss" or the strings "yesterday", "today" and "tomorrow".
-n, --lines= Restrict to a number of entries.
-k, --dmesg Restrict to kernel messages.
-u, --unit= Restrict to a certain Systemd unit.

想要获得更多信息和更多的选项,请看 man journalctl.

/tmp现在是在tmpfs

除非明确指定挂载其他的文件系统到/tmp/etc/fstab中配置, systemd将会挂载/tmp 作为tmpfs。 这意味着它在每次启动时被清空,其大小将被限制在系统的RAM(内存)大小的50%。 要知道这是为什么,以及想要的行为和如何对其进行修改,请参考:API File Systems

配置复杂的引导过程

当迁移到systemd用户通常注意到差异引导过程的时间

  • 启动选项quiet 不仅影响了内核输出,也影响了systemd本身。 再就是,当你为你的系统设置systemd时,可以删除该选项来查看哪些是容易发生的错误。之后,将它添加到一个静默的(和更快的)启动。
  • 甚至通过 quiet 启动选项, systemd 仍然可以通过也传递配置以显示其状态systemd.show_status=1
  • 当不使用 quiet这个选项时,一些日志信息可能会刷满控制台。这是由内核配置造成的(请参考man 5 proc 并查找/proc/sys/kernel/printk)。要调整它通过loglevel=5的引导参数内核(以及根据喜好更新值,例如设置成像1的较低值)。

服务

在某一时刻,系统需要重新启动来让systemd运行(在system模式)。请务必仔细阅读本文,以确保在系统重新启动之前尽可能完整的配置systemd。注意journalctl 在systemd不运行时工作。但 systemctl在systemd不运行时不会做任何工作。登录到正在运行的系统systemd后完成服务配置(启用和启动服务)。

OpenRC 服务

虽然systemd原本旨在支持运行旧的init.d脚本,支持不适合依赖于基于RC像“openrc”的引导,因此它支持在Gentoo上完全禁止。openrc提供了额外的措施来确保初始化。当openrc不是引导系统器时,init.d不能运行(否则,结果将是不可预知的)。

可用服务列表

列出所有可用服务:list-units systemctl:

root #systemctl list-units
UNIT                               LOAD   ACTIVE SUB       DESCRIPTION
boot.automount                     loaded active waiting   EFI System Partition Automount
proc-sys-fs-binfmt_misc.automount  loaded active waiting   Arbitrary Executable File Formats File System Automount Point
...

下列文件扩展名值得关心:

Suffix Description
.service plain service files (e.g. ones just running a daemon directly),
.socket socket listeners (much like inetd),
.path filesystem triggers for services (running services when files change etc.).

作为选择 systemctl工具可用于列出所有服务(包括隐藏的):

root #systemctl --all --full

最后查看未能运行的服务:

root #systemctl --failed

启用、禁用、启动和停止服务

使服务可用的一般方法是使用下面的命令:

root #systemctl enable foo.service

也可以禁用服务:

root #systemctl disable foo.service

这些命令允许使用默认名称默认目标(包括在服务文件的“安装”部分中指定的服务)。但是,有时服务或者不提供该信息,或你喜欢有另一个名称/目标。

请注意,这些命令只能启用或禁用系统能够在下次开机启动;要启动该服务,现在,使用:

root #systemctl start foo.service

同样的服务也可以停止:

root #systemctl stop foo.service

安装自定义单元文件

可以放在自定义单元文件/etc/systemd/system,确认在那里他们将运行后,运行systemctl daemon-reload:

root #systemctl daemon-reload

/usr/lib/systemd/system 被预留给服务包管理器安装的文件。

自定义单元文件

当需要时只有轻微的修改到一个单位时,那里是无需创建 /etc/systemd/system原始的单元文件的完整拷贝。重写包提供的管理单元中的设置可以通过链接文件

  • .d 目录在命名原单位之后 (例如 apache2.d) 在/etc/systemd/system/中。
FILE /etc/systemd/system/apache2.d/mem-limit.confExample of adding/overriding settings in a service file
[Service]
MemoryLimit=1G

重载systemd,需要通知它的变化:

root #systemctl daemon-reload

然后服务需要重新来启动应用的更改:

root #systemctl restart apache2

验证更改的变量被应用到服务:

root #systemctl show --property=MemoryLimit apache2
MemoryLimit=1074000000

根据自定义名称启用服务

当提供的名称在组件"[安装]"部分的不符合期望,由"Alias"提供永久的新名字,这为此通过 customization 所需,可以手动在 /etc/systemd/system/*.wants/ 创建一个链接文件。名称

  • .wants 目录可以指定一个目标或者将取决于新一的另一项服务。

例如,安装mysqld.service 因为db.servicemulti-user.target:

root #ln -s /usr/lib/systemd/system/mysqld.service /etc/systemd/system/multi-user.target.wants/db.service

要禁用该服务,只删除符号链接即可:

root #rm /etc/systemd/system/multi-user.target.wants/db.service

本机服务

Gentoo的安装包已经有systemd组件文件。对于这些服务,这足以使他们开启它。快速的迷你安装组件文件可以在systemd eclass users list看到。

下表列出了与OpenRC一致的服务:

Migration chart
Gentoo package OpenRC service systemd unit Notes
sys-apps/openrc bootmisc systemd-tmpfiles-setup.service 一直 enabled, uses tmpfiles.d
consolefont systemd-vconsole-setup.service 一直 enabled, uses vconsole.conf
devfs
dmesg
fsck fsck*.service 被隐含地隐藏
functions.sh 见附注 bug #373219
hostname (builtin) /etc/hostname
hwclock 见附注 作为 systemd 一直开启(i.e. it is baked in and it is not a unit)
keymaps systemd-vconsole-setup.service 一直 enabled, uses vconsole.conf
killprocs
local
localmount local-fs.target 实际单位是隐式创建的/etc/fstab
modules systemd-modules-load.service 一直 enabled, uses /etc/modules-load.d/*.conf
mount-ro
mtab
netmount remote-fs.target
numlock
procfs (builtin)
root remount-rootfs.service
savecache n/a OpenRC internals
staticroute
swap swap.target actual units are created implicitly from /etc/fstab
swclock
sysctl systemd-sysctl.service sysctl.conf and sysctl.d/
sysfs (builtin)
termencoding systemd-vconsole-setup.service 一直 enabled, uses vconsole.conf
urandom systemd-random-seed-load.service
systemd-random-seed-save.service
app-admin/rsyslog rsyslog rsyslog.service
app-admin/syslog-ng syslog-ng syslog-ng.service
media-sound/alsa-utils alsasound alsa-store.service (enabled by default)
alsa-restore.socket (enabled by default)
net-misc/dhcpcd dhcpcd dhcpcd.service
net-misc/netifrc net.* net@.service systemd wrapper for net.* scripts (comes with net-misc/netifrc)
netctl@.service net-misc/netctl is originally an Arch Linux tool.
NetworkManager.service 对于 <networkmanager-0.9.8.4 : 为了dispatcher开启 NetworkManager-dispatcher.service 。
开启 NetworkManager-wait-online.service 以检测系统是否具有可用的互联网连接。
禁用所有其他管理器 (比如 wicd, dhcpcd) 和 wpa_supplicant.
dhcpcd.service Provided by net-misc/dhcpcd
systemd.networkd.service Part of systemd
net-misc/openntpd ntpd ntpd.service
net-misc/openssh sshd sshd.service 运行 sshd 守护进程
sshd.socket 在inetd-like类基础上运行ssh(对于每个传入连接)
net-wireless/wpa_supplicant wpa-supplicant wpa_supplicant.service D-Bus controlled daemon (e.g. for NetworkManager)
wpa_supplicant@.service interface-specific wpa_supplicant (used like wpa_supplicant@wlan0.service)
net-print/cups cupsd cups.service 常用的启动启动服务
cups.socket socket and path activation (cups only started on-demand)
cups.path
net-wireless/bluez bluetooth bluetooth.service
sys-apps/dbus dbus dbus.service
dbus.socket
sys-apps/irqbalance irqbalance irqbalance.service 仅支持守护程序模式
sys-apps/microcode-ctl microcode_ctl Configure microcode as a module to let it load the microcode itself. Go to "Processor type and features" -> "CPU microcode loading support" and remember to add the right option based on the system having an intel or amd processor.
sys-fs/udev udev udev.service
udev-mount (builtin) /dev is mounted as tmpfs
udev-postmount udev-trigger.service
udev-settle.service
sys-power/acpid acpid acpid.service 它的大部分功能由systemd本身完成,因此请考虑禁用它
x11-apps/xdm (xdm) xdm.service OpenRC常用的 xdm init.d 被 x11-base/xorg-server所取代。systemd所对应的 DM (gdm.service, kdm.service...) 需要被开启。
net-firewall/iptables iptables iptables-store.service
iptables-restore.service

时间服务

自从197年版本的systemd,支持计时器,cron 没有必要安装到systemd系统上。212年版本以来持续性服务被支持,甚至取代了anacron。持久性计时器在下一次有机会当运行的系统断电后,计时器将列入计划任务。

以下是关于如何使运行在用户的环境下,制作简单定时器的一个例子。如果没有登录用户或会话运行。每一个定时服务需要一个定时器和一个服务文件,该文件是由定时器按如下激活的:

FILE ~/.local/share/systemd/user/backup-work.timerExample of a timer running every working day
[Unit]
Description=daily backup work
RefuseManualStart=no
RefuseManualStop=no
 
[Timer]
Persistent=false
OnCalendar=Mon-Fri *-*-* 11:30:00
Unit=backup-work.service
 
[Install]
WantedBy=default.target
FILE ~/.local/share/systemd/user/backup-work.serviceExample of a service triggering backup
[Unit]
Description=daily backup work
RefuseManualStart=no
RefuseManualStop=yes
 
[Service]
Type=oneshot
ExecStart=/home/<user>/scripts/backup-work.sh

首先,告诉systemd要重新扫描服务文件:

user $systemctl --user daemon-reload

可以手动触发备份功能,通过运行下面的命令:

user $systemctl --user start backup-work.service

手动启动和停止计时器如下:

user $systemctl --user start backup-work.timer
user $systemctl --user stop backup-work.timer

最后,激活计时器在每一个系统都启动,运行:

user $systemctl --user enable backup-work.timer

要检查正在运行的服务的最后结果:

user $systemctl --user list-timers

电子邮件故障

如果一个定时服务运行和失败可以发送一封电子邮件通知用户或管理员。这是可能的“OnFailure”节,指定如果服务失败时会发生什么。检测到故障时由一个非零的返回代码调用脚本。

为了这个,改变脚本如下:

FILE ~/.local/share/systemd/user/backup-work.service服务触发备份的例子
[Unit]
Description=daily backup work
RefuseManualStart=no
RefuseManualStop=yes
OnFailure=failure-email@%i.service
 
[Service]
Type=oneshot
ExecStart=/home/<user>/scripts/backup-work.sh

这要求服务failure-email@.service 被安装,它可以在 kylemanna's systemd-utils repository被找到。

替换 cron

上面的计时器和服务文件也可以被添加到/usr/lib/systemd/system 让他们有可用的系统体系。安装部分那时应该说明WantedBy=multi-user.target来系统启动启用服务。

然而, cron也可以通过位于/etc/cron.daily的脚本运行。以及其他的你希望的,日常运行的路径。这种行为可以通过安装 sys-process/systemd-cron仿真systemd。 然后用以下命令激活新cron替换:

root #systemctl enable cron.target
root #systemctl start cron.target

故障排除

/dev/kmsg buffer overrun, some messages lost

问题:启动时系统会显示一个无限循环: /dev/kmsg buffer overrun, some messages lost。到控制台的登录屏幕永远不会出现这一问题,因为在启动过程中系统永远不会获取点。
解决方案 ︰ 大多数情况下,在内核中启用 CONFIG_POWER_SUPPLY_DEBUG 选项时,将会导致此问题。当前的解决方法是在内核中禁用此选项,然后重新编译,安装,并引导新的内核。也可以在Gentoo 论坛上找到解决办法 此线程 。根据一个用户一个论坛,[2] 嵌入式的系统上使用 I2C EEPROM 时,是也会出现此问题。解决办法在这种情况下是禁用 CONFIG_I2C_DEBUG_CORE 内核选项。

在任何地方打开图形会话

默认情况下,当systemd被使用时,它只启动一个getty进程,这会导致一些显示管理器(像GDM)使用剩余Tty来打开图形的会话,这会导致在控制台和图形会话无计划的放置,而这取决于它们的顺序使用。

保持更 "经典" 的行为 (i.e, 控制台将从tty1tty6,图形会话使用剩余的tty) 迫使他总是启动getty关于那些:

root #systemctl enable getty@tty{2,3,4,5,6}.service

LVM

从OpenRC切换到systemd+LVM,你需要正确挂载系统卷并激活LVM服务:

root #systemctl enable lvm2-monitor.service

虽然这可能并不需要激活根(root)卷(如果LVM集成到initramfs),它可能不适用于其他LVM卷,除非该服务被激活。

systemd-bootchart

确保 CONFIG_DEBUG_KERNEL, CONFIG_SCHED_DEBUG,和var>CONFIG_SCHEDSTATS</var> 可用。

KERNEL Enable systemd-bootchart support
File systems  --->
	Pseudo filesystems --->
	[*] /proc file system support
Kernel hacking  --->
	[*] Kernel debugging
	[*] Collect scheduler debugging info
	[*] Collect scheduler statistics

接下来使systemd-bootchart.service开机自启动:

root #systemctl enable systemd-bootchart

这些变化的结果将生成一份位于/run/log/的SVG格式的bootchart报告。每次开机后,你都可以利用网络浏览器查看。

作为systemd-bootchart的替代,可以用以下命令查看

root #systemd-analyze plot > plot.svg

syslog-ng关于 systemd 的资源

没有必要添加unix-dgram('/dev/log');/etc/syslog-ng/syslog-ng.conf配置文件。它会造成 syslog-ng 运行错误 (最新版本syslog-ng-3.7.2会发生这个问题),更新 source src { ...; };syslog-ng article中提到到命令,如下:

FILE /etc/syslog-ng/syslog-ng.conf
# 默认为openrc配置
#source src { system(); internal(); };
 
# systemd
source src { systemd-journal(); internal(); };

sys-fs/cryptsetup配置

systemd似乎不遵守/etc/conf.d/dmcrypt (参见bug #429966)因此需要通过配置/etc/crypttab文件:

FILE /etc/crypttabConfiguration file for encrypted block devices
crypt-home UUID=c25dd0f3-ecdd-420e-99a8-0ff2eaf3f391 -

Make sure to enable the cryptsetup USE flag for sys-apps/systemd. It will install /usr/lib/systemd/system-generators/systemd-cryptsetup-generator that will automatically create a service (cryptsetup@crypt-home.service for above example) for each entry on boot.

检查未能启动的部分

检查未能启动的部分

root #systemctl --failed

开启调式排错模式

得到更多信息,设置/etc/systemd/system.conf

FILE /etc/systemd/system.conf
LogLevel=debug

或启用调试shell,在 tty9打开一个终端。这有助于在引导过程中调试服务。

root #systemctl enable debug-shell.service

e4rat usage

请记得编辑/etc/e4rat.conf,设置'init' 到 /usr/lib/systemd/systemd,否则它将继续使用OpenRC引导。

GRSecurity hardening

启用 grsecurity ,systemd-networkd可能记录有下面的错误:

CODE systemd-networkd error
could not find udev device: Permission denied

错误是因为 systemd-networkd 在非root用户环境下工作,对于这样的用户,使用 grsecurity 拒绝访问完成/sys结构。要禁用这个选项,禁用内核选项CONFIG_GRKERNSEC_SYSFS_RESTRICT

logind 可能也有些许的权限问题CONFIG_GRKERNSEC_PROC 事件,请看bug #472098.

shutdown -rF 不强制fsck

在需要时运行 fsck 需要启用服务systemd fsck 。它不依赖shutdown-fF 选项,但相反它依赖以下的内核启动参数。

Boot parameter Supported options Description
fsck.mode auto
force
skip
Controls the mode of operation. The default is auto, and ensures that file system checks are done when the file system checker deems them necessary. force unconditionally results in full file system checks. skip skips any file system checks.
fsck.repair preen
yes
no
Controls the mode of operation. The default is preen, and will automatically repair problems that can be safely fixed. yes will answer yes to all questions by fsck and no will answer no to all questions.

另请参阅

外部资源

参考