translated

This commit is contained in:
chai001125 2022-11-27 13:26:59 +08:00 committed by GitHub
parent 69cd372b1c
commit 7c288d5e43
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 196 additions and 204 deletions

View File

@ -1,204 +0,0 @@
[#]: subject: (5 reasons sysadmins love systemd)
[#]: via: (https://opensource.com/article/21/4/sysadmins-love-systemd)
[#]: author: (Seth Kenlon https://opensource.com/users/seth)
[#]: collector: (lujun9972)
[#]: translator: (chai001125)
[#]: reviewer: ( )
[#]: publisher: ( )
[#]: url: ( )
5 reasons sysadmins love systemd
======
Systemd's speed and ease make it a popular way to manage modern Linux
systems.
![Woman sitting in front of her laptop][1]
As systems administrators know, there's a lot happening on modern computers. Applications run in the background, automated events wait to be triggered at a certain time, log files are written, status reports are delivered. Traditionally, these disparate processes have been managed and monitored with a collection of Unix tools to great effect and with great efficiency. However, modern computers are diverse, with local services running alongside containerized applications, easy access to clouds and the clusters they run on, real-time processes, and more data to process than ever.
Having a unified method of managing them is an expectation for users and a useful luxury for busy sysadmins. For this nontrivial task, the system daemon, or **systemd**, was developed and quickly adopted by all major Linux distributions.
Of course, systemd isn't the only way to manage a Linux system. There are many alternative init systems, including sysvinit, OpenRC, runit, s6, and even BusyBox, but systemd treats Linux as a unified data set, meant to be manipulated and queried consistently with robust tools. For a busy systems administrator and many users, the speed and ease of systemd is an important feature. Here are five reasons why.
### Boot management
Booting a Linux computer can be a surprisingly rare event, if you want it to be. Certainly in the server world, uptimes are often counted in _years_ rather than months or weeks. Laptops and desktops tend to be shut down and booted pretty frequently, although even these are as likely to be suspended or hibernated as they are to be shut down. Either way, the time since the most recent boot event can serve as a sort of session manager for a computer health check. It's a useful way to limit what data you look at when monitoring your system or diagnosing problems.
In the likely event that you can't remember the last time you booted your computer, you can list boot sessions with systemd's logging tool, `journalctl`:
```
$ journalctl --list-boots
-42 7fe7c3... Fri 2020-12-04 05:13:59 - Wed 2020-12-16 16:01:23
-41 332e99... Wed 2020-12-16 20:07:39 - Fri 2020-12-18 22:08:13
[...]
-1 e0fe5f... Mon 2021-03-29 20:47:46 - Mon 2021-03-29 21:59:29
 0 37fbe4... Tue 2021-03-30 04:46:13 - Tue 2021-03-30 10:42:08
```
The latest boot sessions appear at the bottom of the list, so you can pipe the output to `tail` for just the latest boots.
The numbers on the left (42, 41, 1, and 0 in this example) are index numbers for each boot session. In other words, to view logs for only a specific boot session, you can use its index number as reference.
### Log reviews
Looking at logs is an important method of extrapolating information about your system. Logs provide a history of much of the activity your computer engages in without your direct supervision. You can see when services launched, when timed jobs ran, what services are running in the background, which activities failed, and more. One of the most common initial troubleshooting steps is to review logs, which is easy to do with `journalctl`:
```
`$ journalctl --pager-end`
```
The `--pager-end` (or `-e` for short) option starts your view of the logs at the end of the `journalctl` output, so you must scroll up to see events that happened earlier.
Systemd maintains a "catalog" of errors and messages filled with records of errors, possible solutions, pointers to support forums, and developer documentation. This can provide important context to a log event, which can otherwise be a confusing blip in a sea of messages, or worse, could go entirely unnoticed. To integrate error messages with explanatory text, you can use the `--catalog` (or `-x` for short) option:
```
`$ journalctl --pager-end --catalog`
```
To further limit the log output you need to wade through, you can specify which boot session you want to see logs for. Because each boot session is indexed, you can specify certain sessions with the `--boot` option and view only the logs that apply to it:
```
`$ journalctl --pager-end --catalog --boot 42`
```
You can also see logs for a specific systemd unit. For instance, to troubleshoot an issue with your secure shell (SSH) service, you can specify `--unit sshd` to see only the logs that apply to the `sshd` daemon:
```
$ journalctl --pager-end \
\--catalog --boot 42 \
\--unit sshd
```
### Service management
The first task for systemd is to boot your computer, and it generally does that promptly, efficiently, and effectively. But the task that's never finished is service management. By design, systemd ensures that the services you want to run do indeed start and continue running during your session. This is nicely robust, because in theory even a crashed service can be restarted without your intervention.
Your interface to help systemd manage services is the `systemctl` command. With it, you can view the unit files that define a service:
```
$ systemctl cat sshd
# /usr/lib/systemd/system/sshd.service
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.target
Wants=sshd-keygen.target
[Service]
Type=notify
EnvironmentFile=-/etc/crypto-policies/back-ends/opensshserver.config
EnvironmentFile=-/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D $OPTIONS $CRYPTO_POLICY
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
```
Most unit files exist in `/usr/lib/systemd/system/` but, as with many important configurations, you're encouraged to modify them with local changes. There's an interface for that, too:
```
`$ systemctl edit sshd`
```
You can see whether a service is currently active:
```
$ systemctl is-active sshd
active
$ systemctl is-active foo
inactive
```
Similarly, you can see whether a service has failed with `is-failed`.
Starting and stopping services is nicely intuitive:
```
$ systemctl stop sshd
$ systemctl start sshd
```
And enabling a service to start at boot time is simple:
```
`$ systemctl enable sshd`
```
Add the `--now` option to enable a service to start at boot time or to start it for your current session.
### Timers
Long ago, when you wanted to automate a task on Linux, the canonical tool for the job was `cron`. There's still a place for the cron command, but there are also some compelling alternatives. For instance, the [`anacron` command][2] is a versatile, cron-like system capable of running tasks that otherwise would have been missed during downtime.
Scheduled events are little more than services activated at a specific time, so systemd manages a cron-like function called [timers][3]. You can list active timers:
```
$ systemctl list-timers
NEXT                          LEFT      
Tue 2021-03-30 12:37:54 NZDT  16min left [...]
Wed 2021-03-31 00:00:00 NZDT  11h left [...]
Wed 2021-03-31 06:42:02 NZDT  18h left [...]
3 timers listed.
Pass --all to see loaded but inactive timers, too.
```
You can enable a timer the same way you enable a service:
```
`$ systemctl enable myMonitor.timer`
```
### Targets
Targets are the final major component of the systemd matrix. A target is defined by a unit file, the same as services and timers. Targets can also be started and enabled in the same way. What makes targets unique is that they group other unit files in an arbitrarily significant way. For instance, you might want to boot to a text console instead of a graphical desktop, so the `multi-user` target exists. However, the `multi-user` target is only the `graphical` target without the desktop unit files as dependencies.
In short, targets are an easy way for you to collect services, timers, and even other targets together to represent an intended state for your machine.
In fact, within systemd, a reboot, a power-off, or a shut-down action is just another target.
You can list all available targets using the `list-unit-files` option, constraining it with the `--type` option set to `target`:
```
`$ systemctl list-unit-files --type target`
```
### Taking control with systemd
Modern Linux uses systemd for service management and log introspection. It provides everything from personal Linux systems to enterprise servers with a modern mechanism for monitoring and easy maintenance. The more you use it, the more systemd becomes comfortably predictable and intuitive, and the more you discover how disparate parts of your system are interconnected.
To get better acquainted with systemd, you must use it. And to get comfortable with using it, [download our cheat sheet][4] and refer to it often.
--------------------------------------------------------------------------------
via: https://opensource.com/article/21/4/sysadmins-love-systemd
作者:[Seth Kenlon][a]
选题:[lujun9972][b]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://opensource.com/users/seth
[b]: https://github.com/lujun9972
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/OSDC_women_computing_4.png?itok=VGZO8CxT (Woman sitting in front of her laptop)
[2]: https://opensource.com/article/21/2/linux-automation
[3]: https://opensource.com/article/20/7/systemd-timers
[4]: https://opensource.com/downloads/linux-systemd-cheat-sheet

View File

@ -0,0 +1,196 @@
[#]: subject: (5 reasons sysadmins love systemd)
[#]: via: (https://opensource.com/article/21/4/sysadmins-love-systemd)
[#]: author: (Seth Kenlon https://opensource.com/users/seth)
[#]: collector: (lujun9972)
[#]: translator: (chai001125)
[#]: reviewer: ( )
[#]: publisher: ( )
[#]: url: ( )
系统管理员喜欢 systemd 的 5 个理由
======
>Systemd 的速度和易用性使其成为管理现代 Linux 系统的流行方式。
![Woman sitting in front of her laptop][1]
系统管理员知道一台运行着的**现代计算机**上会发生了很多事情:应用程序在后台运行、预定事件等待在特定时间被触发、事件写入日志文件、发送状态报告。在以前,不同的进程可以通过一系列 Unix 工具,来进行有效地管理和监控。然而,现代的计算机运作更为复杂了:本地服务与容器化应用程序一同运行、能够轻松访问云及其运行的集群、有实时进程以及有比以往都多的数据。
拥有统一的管理方法不但是用户想要的,也是忙碌的系统管理员所迫切渴望的。为了完成这项重要的任务,<ruby>系统守护进程<rt> system daemon </rt></ruby>**systemd** 被开发出来,并迅速被所有主要的 Linux 发行版所采用了。
当然systemd 并不是管理 Linux 系统的唯一方式,还有许多其他可供选择的 init 系统,包括 sysvinit、OpenRC、runit、s6和 BusyBox但 systemd 将 Linux 视为一个统一的数据集,意味着 systemd 能用强大的工具对 Linux 进行一致的操作和查询。对于忙碌的系统管理员和许多用户来说systemd 的速度和易用性是一个重要的特性。有以下的五个原因。
### systemd 的 <ruby>计算机启动管理<rt> Boot management </rt></ruby>
启动 Linux 计算机可能是一件非常罕见的事情。**服务器**的正常运行时间通常以 _年_ 来计算,而不是月或周。**笔记本电脑和台式机**可能会频繁地关闭和启动,但更多的时候它们是被挂起或休眠了。无论哪种类型,**最近一次开机的时刻**都可用于检查一段时间内的计算机健康情况,因为当你在监视系统或诊断问题时,这一时刻能够限制查看的数据量大小,从而让你快速地找到问题所在。
如果你不记得上次启动计算机的时间,你可以使用 systemd 的日志记录工具 `journalctl`,来列出计算机的所有启动时间:
```
$ journalctl --list-boots
-42 7fe7c3... Fri 2020-12-04 05:13:59 - Wed 2020-12-16 16:01:23
-41 332e99... Wed 2020-12-16 20:07:39 - Fri 2020-12-18 22:08:13
[...]
-1 e0fe5f... Mon 2021-03-29 20:47:46 - Mon 2021-03-29 21:59:29
 0 37fbe4... Tue 2021-03-30 04:46:13 - Tue 2021-03-30 10:42:08
```
最近一次启动时间输出在结果列表的底部,因此你可以通过管道将输出传输到 `tail`,来查看最近一次启动时间。
左侧的数字(在本例中为 42、41、1 和 0是每个启动时间的索引号。换句话说如果你要查看某一特定启动时间的日志你可以使用这个索引号作为参数。
### systemd 的 <ruby>日志记录<rt> Log reviews </rt></ruby>
查看日志是推断系统信息的一种重要方法。日志提供了计算机运行的大部分事件的历史记录,这些记录都是在没有你直接监督的情况下生成的。通过日志,你可以知道某一服务何时启动、定时任务何时运行、哪些服务在后台运行、哪些事件运行失败等等信息。故障排除的初始步骤是使用 systemd 的 `journalctl` 来查看日志:
```
`$ journalctl --pager-end`
```
`--pager-end` 选项(简写为 `-e`)会在 `journalctl` 的输出末尾开始查看日志,因此要查看更早发生的日志,你需要向上滚动。
Systemd 维护一个错误信息的“目录”,错误信息包含错误记录、可能的解决方案、支持论坛的指针和开发人员文档。这个错误信息的“目录”能为日志事件提供重要的上下文,否则它可能会成为海量日志中的一个令人困惑的信息,或者更糟的是,错误信息可能会完全被忽视。要将错误消息与日志中的解释性文本放在一起输出,你可以使用`--catalog`选项(简写为 `-x`
```
`$ journalctl --pager-end --catalog`
```
要进一步限定日志输出,你可以指定要查看哪个启动时间的日志。因为每个启动时间都有索引,所以你可以使用 `--boot` 选项,来指定某个启动时间,并仅查看该启动时间的日志:
```
`$ journalctl --pager-end --catalog --boot 42`
```
你还可以查看特定 systemd 单元的日志。例如,要解决 SSH 服务的问题,你可以指定 `--unit sshd` 选项,来仅查看适用于 `sshd` 守护程序的日志:
```
$ journalctl --pager-end \
\--catalog --boot 42 \
\--unit sshd
```
### systemd 的 <ruby>服务管理<rt> Service management </rt></ruby>
systemd 的第一个任务就是启动你的计算机systemd 会迅速、高效且有效地执行这一任务。但 systemd 一直需要管理的任务是 <ruby>服务管理<rt> service management </rt></ruby>,因为 systemd 需要确保你要运行的服务确实在你的会话期间启动并继续运行。systemd 的这一功能非常稳健,因为理论上即使是一个崩溃的服务也可以在没有你干预的情况下重新启动。
你可以通过使用 `systemctl` 命令,来接入 systemd 管理服务接口,并能查看定义服务的 <ruby>单元文件<rt> unit files </rt></ruby>
```
$ systemctl cat sshd
# /usr/lib/systemd/system/sshd.service
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.target
Wants=sshd-keygen.target
[Service]
Type=notify
EnvironmentFile=-/etc/crypto-policies/back-ends/opensshserver.config
EnvironmentFile=-/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D $OPTIONS $CRYPTO_POLICY
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
```
大多数单元文件都在 `/usr/lib/systemd/system/` 目录下,但是你也可以在本地更改文件中的配置,请使用以下的接口:
```
`$ systemctl edit sshd`
```
你可以通过 `is-active` 选项,来查看某一服务当前是否处于活动状态:
```
$ systemctl is-active sshd
active
$ systemctl is-active foo
inactive
```
同样地,你可以通过 `is-failed` 选项,来查看某一服务是否运行失败了。
```
$ systemctl is-failed sshd
```
使用以下命令,来启动或者停止某一服务:
```
$ systemctl stop sshd
$ systemctl start sshd
```
使用以下命令,让某一服务在开机时自启动:
```
`$ systemctl enable sshd`
```
添加 `--now` 选项,让某一服务在开机时启动或在当前会话中立即启动。
### systemd 的 Timers 管理
在以前,当你想在 Linux 上自动执行一项任务时,你可以使用的工具是 `cron`。如今,`cron` 命令仍能使用,但对于在 Linux 上自动执行一项任务,也有一些其他好用的替代方案。例如,[`anacron` 命令][2] 是一个多功能的、类似于 `cron` 的系统,它能够运行在停机期间可能会错过的任务。
计划的事件就是在特定时间需要激活的服务。systemd 管理一个名为 [timers][3] 的工具,它类似 cron 的功能。你可以使用以下命令,来列出活动中的计时器:
```
$ systemctl list-timers
NEXT                          LEFT      
Tue 2021-03-30 12:37:54 NZDT  16min left [...]
Wed 2021-03-31 00:00:00 NZDT  11h left [...]
Wed 2021-03-31 06:42:02 NZDT  18h left [...]
3 timers listed.
Pass --all to see loaded but inactive timers, too.
```
你可以使用以下命令,来像启用服务一样启用计时器:
```
`$ systemctl enable myMonitor.timer`
```
### systemd 的 Targets 管理
Targets 是 systemd 的最后一个主要组成部分。Targets 是一个单元文件与服务和计时器相同Targets 也可以以相同的方式启动和启用。Targets 的独特之处在于它们以一种任意重要的方式对其他单元文件进行分组。例如,你可能希望开机到文本控制台界面而不是图形桌面,因此有 `multi-user` Target 存在。但是,`multi-user` Target 只是没有桌面单元文件作为依赖项的 `graphical` target。
简而言之Targets 是一种将服务、计时器甚至其他的 Targets 收集在一起,以表示机器的预期状态的简单方法。
事实上,在 systemd 中,重启、关机或关闭操作只是又一个 Target。
你可以使用 `list-unit-files` 选项,来列出所有可用的 Targets`--type` 选项将其限制为 `target`
```
`$ systemctl list-unit-files --type target`
```
### 快使用 systemd 对计算机进行控制管理吧
现代的 Linux 使用 systemd 进行服务管理和日志检查。从个人的 Linux 系统到企业服务器systemd 都能提供有效的监控,并且十分易于维护。你越频繁地使用 systemdsystemd 对你而言就会变得越容易预测和直观,你就会明白系统的不同部分是如何相互关联的。
为了更好地熟悉 systemd请现在就开始使用它吧。请 [下载关于 systemd 相关命令的备忘录][4],你可以在实际使用 systemd 中经常参考这个备忘录,这样你就能更快熟悉使用 systemd 啦!
--------------------------------------------------------------------------------
via: https://opensource.com/article/21/4/sysadmins-love-systemd
作者:[Seth Kenlon][a]
选题:[lujun9972][b]
译者:[chai001125](https://github.com/chai001125)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://opensource.com/users/seth
[b]: https://github.com/lujun9972
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/OSDC_women_computing_4.png?itok=VGZO8CxT (Woman sitting in front of her laptop)
[2]: https://opensource.com/article/21/2/linux-automation
[3]: https://opensource.com/article/20/7/systemd-timers
[4]: https://opensource.com/downloads/linux-systemd-cheat-sheet