美文网首页
412.【Linux】systemd 配置文件

412.【Linux】systemd 配置文件

作者: 七镜 | 来源:发表于2022-08-30 23:09 被阅读0次

示例 service 文件如下 ,(知道怎么配置 systemd 就能玩开机自启动啦!)

[Unit]
Description=qijing daemon

[Service]
Type=simple
ExecStart=/usr/bin/qijing

[Install]
WantedBy=multi-user.target

1.[Unit]

通常是配置文件的第一个区块,用来定义 Unit 的元数据,以及配置与其他 Unit 的关系。它的主要字段如下。

  1. Description:简短描述
  2. Documentation:文档地址
  3. Requires:当前 Unit 依赖的其他 Unit,如果它们没有运行,当前 Unit 会启动失败
  4. Wants:与当前 Unit 配合的其他 Unit,如果它们没有运行,当前 Unit 不会启动失败
  5. BindsTo:与Requires类似,它指定的 Unit 如果退出,会导致当前 Unit 停止运行
  6. Before:如果该字段指定的 Unit 也要启动,那么必须在当前 Unit 之后启动
  7. After:如果该字段指定的 Unit 也要启动,那么必须在当前 Unit 之前启动
  8. Conflicts:这里指定的 Unit 不能与当前 Unit 同时运行
  9. Condition...:当前 Unit 运行必须满足的条件,否则不会运行
  10. Assert...:当前 Unit 运行必须满足的条件,否则会报启动失败

2.[Install]

通常是配置文件的最后一个区块,用来定义如何启动,以及是否开机启动。它的主要字段如下。

  1. WantedBy:它的值是一个或多个 Target,当前 Unit 激活时(enable)符号链接会放入/etc/systemd/system目录下面以 Target 名 + .wants后缀构成的子目录中
  2. RequiredBy:它的值是一个或多个 Target,当前 Unit 激活时,符号链接会放入/etc/systemd/system目录下面以 Target 名 + .required后缀构成的子目录中
  3. Alias:当前 Unit 可用于启动的别名
  4. Also:当前 Unit 激活(enable)时,会被同时激活的其他 Unit

3. [Service]

用来 Service 的配置,只有 Service 类型的 Unit 才有这个区块。它的主要字段如下。

  1. Type:定义启动时的进程行为。它有以下几种值。
  2. Type=simple:默认值,执行ExecStart指定的命令,启动主进程
  3. Type=forking:以 fork 方式从父进程创建子进程,创建后父进程会立即退出
  4. Type=oneshot:一次性进程,Systemd 会等当前服务退出,再继续往下执行
  5. Type=dbus:当前服务通过D-Bus启动
  6. Type=notify:当前服务启动完毕,会通知Systemd,再继续往下执行
  7. Type=idle:若有其他任务执行完毕,当前服务才会运行
  8. ExecStart:启动当前服务的命令
  9. ExecStartPre:启动当前服务之前执行的命令
  10. ExecStartPost:启动当前服务之后执行的命令
  11. ExecReload:重启当前服务时执行的命令
  12. ExecStop:停止当前服务时执行的命令
  13. ExecStopPost:停止当其服务之后执行的命令
  14. RestartSec:自动重启当前服务间隔的秒数
  15. Restart:定义何种情况 Systemd 会自动重启当前服务,可能的值包括always(总是重启)、on-16. success、on-failure、on-abnormal、on-abort、on-watchdog
  16. TimeoutSec:定义 Systemd 停止当前服务之前等待的秒数
  17. Environment:指定环境变量

systemd 还是值得好好学习学习的,最近遇到的问题就是:systemd 配置的服务,nohupscreen这种后台执行命令不生效,原因待排查。

相关文章

网友评论

      本文标题:412.【Linux】systemd 配置文件

      本文链接:https://www.haomeiwen.com/subject/rkernrtx.html