コンピュータの起動を速くするだけではありません。
systemd が最初に登場したとき、起動時間を短縮できる方法について多くのニュースが流れました。この機能はほとんどの人にとって魅力的です (再起動しない人にとってはそれほど魅力的ではありません)。そのため、多くの点で、それが今日でも評判になっています。 systemd はブートプロセス中にサービスを並行して開始する役割を果たしますが、それ以上のことを行います。ここでは、systemd ができることに気づいていないかもしれないが、活用すべき 3 つのことを紹介します。
これまでに ps
を使用したことがある場合、または 最上位
だけを使用したことがある場合コマンドを実行すると、コンピューターで常に数百のプロセスが実行されていることがわかります。場合によっては、これは、コンピューターまたはそのユーザーが何をしているかを理解するために必要な情報に過ぎません。また、本当に必要なのは全体的な概要であることもあります。
systemd-cgtop
コマンドは、制御グループ cgroup タスク スケジュールに基づいてコンピューターの負荷を簡単に表示します。 コントロール グループ は最新の Linux にとって重要であり、基本的にコンテナーと Kubernetes の基礎となるサポート構造です (これがクラウド コンピューティングが拡張できる理由です) が、家庭用コンピューターでも役立つ構造でもあります。たとえば、 systemd-cgtop
の出力から、システム プロセスではなく、ユーザー プロセスの負荷を確認できます。
Control Group Proc+ %CPU MemoryInput/s Output/s / 1835.0 1.6G 0B 3.0M user.slice42.8 1.1G 0B 174.7K user.slice/user-1000.slice42.8 968.2M 0B 174.7K system.slice 652.2 1.5G 0B 2.8M
ユーザー空間のプロセスだけを表示することもできます。ユーザー空間プロセスとカーネルスレッドを見てください。
これは決して、 top
や ps
に代わるものではなく、異なる独自の視点システムからあなたを観察するためのものです。コンテナーはコントロール グループを使用するため、コンテナーを実行する場合、これは重要になる可能性があります。
Cron は Linux の古典的なコンポーネントです。 Cron は、定期的に何かが起こるようにスケジュールしたい場合に使用します。信頼性が高く、システムにうまく統合されます。
問題は、Cron が一部のコンピューターがシャットダウンされることを理解していないことです。 cron ジョブを午前 0 時にスケジュールしていても、毎日 23:59 にコンピュータをシャットダウンした場合、cron ジョブは実行されません。 Cron には、夜間に見逃したジョブを検出するツールがありません。
この質問に対する答えとしては、 Anacron という優れた答えがありますが、Cron ほど統合されていません。 Anacron を実行するには、多くのセットアップを行う必要があります。
2 番目のオプションは systemd タイマーです。 Cron と同様に、組み込みですぐに使用できます。ユニット ファイルを作成する必要があります。これは、単一行の Crontab エントリよりも明らかに手間がかかりますが、非常に簡単でもあります。たとえば、次のユニット ファイルは、起動後 30 分に、ただし 1 日に 1 回だけ、仮想のバックアップ スクリプトを実行します。これにより、コンピュータが確実にバックアップされ、1 日に複数回バックアップを試行することがなくなります。
[Unit] Description=Backup Requires=myBackup.service [Timer] OnBootSec=30min OnUnitActiveSec=1d [Install] WantedBy=timers.target
もちろん、介入してタスクの実行を促すこともできます。 OnUnitActiveSec
ディレクティブのおかげで、systemd は手動でアクティブ化したジョブを実行しようとしません。
容器使启动一个复杂的服务变得非常容易。你可以在短短几分钟内运行一个 Mattermost 或 Discourse 服务器。在某些情况下,困难的部分是在你运行容器后管理和监控它们。Podman 使得管理它们变得容易,但是用什么来管理 Podman 呢?嗯,你可以使用 systemd。
Podman 有一个内置的命令来生成单元文件,这样你的容器就可以被 systemd 管理和监控:
$ podman generate systemd --new --files --name example_pod
然后你所要做的就是启动服务:
$ systemctl --user start pod-example_pod.service
和其他服务一样,systemd 确保你的容器荚在任何情况下都能运行。它记录问题,你可以用 journalctl
和其他重要的日志来查看,你也可以用 systemd-cgtop
在控制组中监控它的活动。
它不是 Kubernetes 平台,但对于一两个容器来说,你只需要在可靠和可预测的基础上提供服务,Podman 和 systemd 是一对很棒的组合。
systemd 的内容还有很多,你可以从作者 David Both 的新书《systemd 实用指南》中了解基础知识,以及很多实用的技巧。
以上がsystemd でできる 3 つの驚くべきことの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。