如何删除 sysV 服务的 systemd 包装脚本并使用单元文件?

如何删除 sysV 服务的 systemd 包装脚本并使用单元文件?

我正在尝试取消配置或删除systemd旧 sysV 服务的包装器脚本。该包装器由 Debian 软件包提供,因此我不能直接删除它。

包装器显示为工件并列为“生成”:

$ systemctl list-unit-files | grep -i -E 'rng|rand'
rng-tools.service                      generated
systemd-random-seed.service            static
urandom.service                        static

我添加了一项新systemd服务来替换它创建和修改 systemd 单元文件:

# touch /etc/systemd/system/rng-tools.service
# chmod 664 /etc/systemd/system/rng-tools.service
# emacs /etc/systemd/system/rng-tools.service
<edit file>

但是,当我尝试启用新服务文件时,将使用旧的 sysV 脚本:

# systemctl enable rng-tools
Synchronizing state of rng-tools.service with SysV service script with /lib/systemd/systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable rng-tools

搜索结果为 0 次,可删除旧包装。我得到了很多类似的点击,比如创建一个包装脚本。但我还没有找到有关从systemd的数据库中删除一个的信息。

如何取消配置或删除 sysV 服务的 systemd 包装脚本?


这是斯蒂芬建议后的结果。新的rng-tools.service正在使用:

$ systemctl status rng-tools
● rng-tools.service - Entropy daemon for /dev/random using a hardware RNG
   Loaded: loaded (/etc/systemd/system/rng-tools.service; enabled; vendor preset
   Active: failed (Result: exit-code) since Mon 2018-10-15 07:19:32 EDT; 20min a
 Main PID: 674 (code=exited, status=1/FAILURE)

和:

# journalctl -b -u rng-tools.service
-- Logs begin at Mon 2018-10-15 07:19:29 EDT, end at Mon 2018-10-15 07:49:13 EDT. --
Oct 15 07:19:31 beaglebone systemd[1]: Started Entropy daemon for /dev/random using a hardware RNG.
Oct 15 07:19:31 beaglebone rngd[674]: can't open /dev/hwrng: No such file or directory
Oct 15 07:19:32 beaglebone systemd[1]: rng-tools.service: Main process exited, code=exited, status=1/FAILURE
Oct 15 07:19:32 beaglebone systemd[1]: rng-tools.service: Unit entered failed state.
Oct 15 07:19:32 beaglebone systemd[1]: rng-tools.service: Failed with result 'exit-code'.

和:

# dd if=/dev/hwrng count=16 bs=1
▒▒▒▒ȿ▒3▒▒ ▒▒#16+0 records in
16+0 records out
16 bytes (16 B) copied, 0.00942799 s, 1.7 kB/s

为了完整起见,这是新的rng-tools.service

# cat /etc/systemd/system/rng-tools.service
# ...

[Unit]
Description=Entropy daemon for /dev/random using a hardware RNG
After=syslog.target
Requires=syslog.target

[Service]
Type=simple
ExecStart=/usr/sbin/rngd -r /dev/hwrng -f

[Install]
WantedBy=basic.target

答案1

Synchronizing state of rng-tools.service with SysV service script with /lib/systemd/systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable rng-tools

仅意味着 systemd “意识到”存在一个sysvinit-style init 脚本,并且在考虑服务状态时需要将其考虑在内rng-tools。这并不意味着它会使用用于管理服务的初始化脚本。

如果初始化脚本和单元文件都存在,systemd 将使用后者(至少在服务未运行时)。

您可以通过运行查看哪个文件用于启动服务systemctl status; “已加载”行将显示使用了哪个脚本。例如,这是一个同时具有 systemd 单元和 init 脚本的服务:

● infnoise.service - Wayward Geek InfNoise TRNG driver
   Loaded: loaded (/lib/systemd/system/infnoise.service; enabled; vendor preset: enabled)

这是一个只有初始化脚本的服务:

● sensord.service - LSB: lm-sensors daemon
   Loaded: loaded (/etc/init.d/sensord; generated; vendor preset: enabled)

检查您的服务应该显示 systemd 正在使用您的新单元。

如果一切都失败了,你delete /etc/init.d/rng-tools:它应该作为配置文件进行跟踪,并dpkg会注意到它已被删除,并且不会在软件包升级时恢复它。/etc属于系统管理员,而不是软件包系统,尽管软件包可以在那里安装文件。

相关内容