专题:『systemd』
[COMMAND]
Systemd Daemons: systemd networkd journald logind "user session" Systemd units: service[系统服务] mount[文件系统挂载点] automount[自动挂载点] target[多个unit组成的一个组] timer[定时任务] device[硬件设备] socket[进程间通信的socket] swap[swap文件] path[文件或路径] snapshot[systemd快照,可切换回某个运行状态] slice[进程组] scope[不是由systemd启动的外部进程] Systemd Utilities: systemctl journalctl loginctl hostnamectl localectl timedatectl etc. systemctl rescue 无须重启直接切换至救援模式
systemctl get-default
查看启动时的默认target
systemctl isolate/set-default *.target
isolate切换target(将关闭前一个target中所有不属于后一个target的进程)
set-default用于设置新的默认target,实质是将目标target软链接至/etc/systemd/system/default.target systemd-analyze [critical-chain [*.unit]] 查看系统启动耗时,可显示单个服务信息 loginctl user-status USERNAME 显示指定用户的所有进程信息 loginctl kill-user USERNAME 终止指定用户的所有进程 systemctl [list-units] --all/--failed --state=inactive --type=service --all显示所有状态的units --failed仅显示启动失败的 --statue=inactive仅显示没有配置文件工或启动失败的 --type指定要显示的unit类别 systemctl [-H root@10.1.1.1] status [*.unit] 不加参数,则显示当前系统状态 指定远程主机、unit(如某个service),则显示指定unit的状态 systemctl show [-p CPUShares] [*.unit] 显示系统或指定unit的所有底层参数,-p可用于指定仅显示特定参数 systemctl [--runtime] set-property *.unit CPUShares=500 设置某个unit的指定属性,--runtime表示临时生效,直到下一次系统重启 systemctl is-active/is-failed/is-enabled *.unit 判断某个unit处于何种状态:正常运行、启动失败、随机启动,常用于脚本条件判断 systemctl kill [--signal=SIGKILL/HUP etc.] [--kill-who=main/control/all] *.unit 不同于stop方式,kill是暴力终止一个服务的所有子进程,--kill-who选项可选择只终止主进程、控制进程或所有进程 systemctl daemon-reload 使所有更改过的配置文件生效 systemctl list-dependencies [--all] *.unit 列出一个unit的所有依赖(子units),默认不会展开其中的target,--all可展开target中的子项
journalctl:显示所有日志,默认less分页显示
journalctl -b -1:查看上一次启动的日志,-0代表最近一次
journalctl -k:只查看内核日志
journalctl --since="2016-10-11 11:10:54" --until="2020-01-29 00:00:36":按精确的起始时间查询日志
journalctl -f:类似于tail -f的功能,动态监控日志
journalctl -n 100:查看最新的100条日志
journalctl -u xxx.unit -u yyy.unit:查看指定unit的日志,可合并指定多个
journalctl _PID:查看指定pid进程的日志
journalctl --disk-usage:显示日志占用的磁盘空间
journalctl -o:指定日志显示的格式
journalctl -p:指定日志显示的级别「共有8个级别」:"emerg" (0), "alert" (1), "crit" (2), "err" (3), "warning" (4), "notice" (5), "info" (6),"debug" (7)
/etc/systemd/journald.conf中可配置日志保存期限、日志最大容量等选项
systemctl list-unit-files [--type=service]
列出所有unit配置文件,--type用于指定unit类型;显示结果有四种状态:enabled[已建立启动链接 #但不一定当前正在运行] disabled[没有建立启动链接] static[此unit无install部分,不能独立启动,只能作为其它unit的依赖]、masked[禁止启动]
systemctl cat *.unit
查看某个unit的配置文件内容
[CONFIG_FILES]
Systemd默从/etc/systemd/system、/usr/lib/systemd/system中读取unit配置文件,前者优先级更高;更底层的配置文件在/etc/systemd、/usr/lib/两个目录下,如/etc/systemd/journald.conf存放系统日志配置文件
/etc/systemd/system/multi-user.target.wants目录中的unit是为开机启动者
可手动链接unit至上述wants目录下,或使用“systemctl enable/disable *.unit”操作,或省略后缀.unit,systemd默认为.unit
将某个unit的配置文件链接或取消链接至/dev/null,即可设置禁止或允许其启动,等效于“systemctl mask/unmask *.unit”
配置文件通常分为三部分:[Unit]、[Install]、[Service],其中Service是service类unit特有
[Unit]
#通常是配置文件的第一个区块,用来定义 Unit 的元数据,以及配置与其他 Unit 的关系
Description:简短描述
Documentation:文档地址
Requires:当前 Unit 依赖的其他 Unit,如果它们没有运行,当前 Unit 会启动失败
Wants:与当前 Unit 配合的其他 Unit,如果它们没有运行,当前 Unit 不会启动失败
BindsTo:与Requires类似,它指定的 Unit 如果退出,会导致当前 Unit 停止运行
Before:如果该字段指定的 Unit 也要启动,那么必须在当前 Unit 之后启动
After:如果该字段指定的 Unit 也要启动,那么必须在当前 Unit 之前启动 #注意:after、before只涉及启动顺序,并不一定存在依赖关系
Conflicts:这里指定的 Unit 不能与当前 Unit 同时运行
Condition...:当前 Unit 运行必须满足的条件,否则不会运行
Assert...:当前 Unit 运行必须满足的条件,否则会报启动失败
[Service]
#只有 Service 类型的 Unit 才有这个区块
Type:定义启动时的进程行为。它有以下几种值
Type=simple:默认值,执行ExecStart指定的命令,启动主进程 Type=forking:以 fork 方式从父进程创建子进程,创建后父进程会立即退出 Type=oneshot:每次系统启动只运行一次,执行结束后,再继续往下执行其它进程 Type=dbus:当前服务通过D-Bus启动 Type=notify:当前服务启动完毕,会通知Systemd,再继续往下执行 Type=idle:若有其他任务执行完毕,当前服务才会运行
ExecStart:启动当前服务的命令 ExecStartPre:启动当前服务之前执行的命令 ExecStartPost:启动当前服务之后执行的命令 ExecReload:重启当前服务时执行的命令 ExecStop:停止当前服务时执行的命令 ExecStopPost:停止当其服务之后执行的命令 RestartSec:自动重启当前服务间隔的秒数 Restart:定义何种情况 Systemd 会自动重启当前服务,可能的值包括no(默认值)、always、on-success、on-failure、on-abnormal、on-abort、on-watchdog TimeoutSec:定义 Systemd 停止当前服务之前等待的秒数 Environment:指定环境变量EnvironmentFile
:指定当前服务的环境参数文件,其内部的“key=value”
键值对,可以用$key
的形式,在当前配置文件中引用
连词号(-),表示"抑制错误",即发生错误的时候,不影响其他命令的执行 例如: EnvironmentFile=-/etc/xxd,就表示即使/etc/xxd文件不存在,也不会抛出错误
[Install]
#通常是配置文件的最后一个区块,用来定义如何启动,以及是否开机启动
WantedBy:它的值是一个或多个 Target,当前 Unit 激活时(enable)符号链接会放入/etc/systemd/system目录下面以 Target 名 + .wants后缀构成的子目录中 RequiredBy:它的值是一个或多个 Target,当前 Unit 激活时,符号链接会放入/etc/systemd/system目录下面以 Target 名 + .required后缀构成的子目录中 Alias:当前 Unit 可用于启动的别名 Also:当前 Unit 激活(enable)时,会被同时激活的其他 Unit
示例: root # systemctl cat sshd.service # /usr/lib64/systemd/system/sshd.service [Unit] Description=OpenSSH server daemon After=syslog.target network.target auditd.service [Service] ExecStartPre=/usr/bin/ssh-keygen -A ExecStart=/usr/sbin/sshd -D -e ExecReload=/bin/kill -HUP $MAINPID [Install] WantedBy=multi-user.target # /run/systemd/system/sshd.service.d/50-CPUShares.conf [Service] CPUShares=500
[Timer]
[Unit] Description=Run myscript weekly [Timer] # 按日历规划执行,如每天的11点11分11秒执行Unit=项指定的service OnCalendar=*-*-* 11:11:11 # 首次运行要在启动后10分钟后 OnBootSec=10min # 每次运行间隔时间 OnUnitActiveSec=1w # 定义时间精度,默认1min,可用时间单位如h、m、s、us(毫秒);如下定义为1h代表任务会在指定的时间后1小时内执行 AccuracySec=1h # 指定要执行的任务,若任务名称和timer名称一致,此项可忽略 Unit=myscript.service [Install] WantedBy=multi-user.target
注意:对应的service无需enable,只须enable关联的timer即可
Systemd开关机流程:
https://www.freedesktop.org/software/systemd/man/bootup.html#System%20Manager%20Bootup
HADEX_ FROM HELL.