美文网首页
俯观 systemd 系统

俯观 systemd 系统

作者: 癞痢头 | 来源:发表于2019-10-13 00:55 被阅读0次

1. 序言

centos 升级到7.0 以后,自带systemd 系统, 从长远来看,使用systemctl 管理服务是一个趋势。但是实际用起来的时候,搜索引擎出来的各种资料,还是一片抓瞎,有种老虎吃天,无法下爪的感觉。这篇文章记录一下自己查阅的资料, 希望能帮助刚开始使用systemd 的小鲜菜,从整体上来了解systemd的运行, 做到知其然,知其所以然。

2. 参考文章和文档

2.1 走进Linux之systemd启动过程
从这篇文章可以从系统角度理解systemd启动运行过程, 管理范围
2.2 Systemd Boot Process a Close Look in Linux
  这是2.1文章的英文版
2.3 Systemd 入门教程:命令篇
熟悉systemd系统后,这篇文章是个不错的手册,用来查询一些常用的命令很方便
2.4 journalctl
这片文章讲了journald 日志的一片基本操作
2.5 最重要的参考,当然是 man page 了
最权威, 齐全的说明了, 但全英文的,看起来比较吃力,这个如果看懂了,其它的就不用看了, 其它文章都是从 manPage 来的,这个是祖宗
  • $ man systemd Homepage

这就是systemd 引导系统启动过程和 管理服务运行原理

  • $ man systemctl

控制systemd 系统, 管理服务,基本日常使用的命令都在这里和 journalctl 里 了

  • $ man systemd.unit

Unit 配置的详细文档,如果不知道service 怎么写, 看这里,准错不了
更细分一点的文档 systemd.special(7), systemd.service(5), systemd.socket(5), systemd.device(5), systemd.mount(5),systemd.automount(5), systemd.swap(5), systemd.target(5), systemd.path(5), systemd.timer(5), systemd.snapshot(5), systemd.scope(5),systemd.slice(5), systemd.time

  • $ man journalctl

这个是查看 systemd-journald.service 日志系统的工具,改天可以写个专题

  • $ man machinectl

虚拟机 虚拟机和容器一类的管理工具

  • $ man loginctl

登录管理相关的模块

manPage 是个好东西, 没空要多看

3. Systemd(系统管理守护进程)主要用于引导和服务管理程序

3.1 让我们看下Systemd的一些核心功能。
  • Systemd支持并发引导过程从而可以更快启动
  • 通过控制组来追踪进程,而不是PID
  • 优化了处理引导过程和服务之间依赖的方式
  • 监控已启动的服务;也支持重启已崩溃服务
  • 包含了systemd-login模块用于控制用户登录
  • 支持加载和卸载组件
  • 记录事件的Journald模块和记录系统日志的syslogd模块
3.2 systemd 架构图
systemd 架构图

从这里,可以看到, 我们最长用的命令 都是systemd 辅助工具类的

  • systemctl 管理
  • journalctl 日志
  • notify 通知
  • analyze 分析

4. service 服务配置

4.1毕竟记录是为了写service, 这里写一下service 的写法吧,先来个例子

Example-1. Foo.service

[Unit]
Description=Foo

[Service]
ExecStart=/usr/sbin/foo-daemon

 [Install]
WantedBy=multi-user.target
4.2 service 服务

service 文件 是一个以 .service 结尾的配置文件, 包含管理进程和被systemd 管理的配置。

一般的 unit 文件只有 "[Unit]" 和 "[Install]" 两个指令块, service 服务包额外包含一个 "[Service]"指令块

4.2.1 [Unit]

  • Description:简单描述
  • Documentation:服务的启动文件和配置文件
  • Requires:当前Unit依赖的其他Unit,如果它们没有运行,当前Unit会启动失败
  • Wants:与当前Unit配合的其他Unit,如果它们没有运行,不影响当前Unit的启动
  • BindsTo:与Requires类似,它指定的Unit如果退出,会导致当前Unit停止运行
    Before:如果该字段指定的Unit也要启动,那么必须在当前Unit之后启动
    After:如果该字段指定的Unit也要启动,那么必须在当前Unit之前启动
    Conflicts:这里指定的Unit不能与当前Unit同时运行
    Condition...:当前Unit运行必须满足的条件,否则不会运行
    Assert...:当前Unit运行必须满足的条件,否则会报启动失败

4.2.2 [Service]

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

4.2.3 [Install]
通常是配置文件的最后一个区块,用来定义运行模式(Target)、Unit别名等设置,以及是否开机启动,它的主要字段如下:

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

5.记录一些自己还不知道的命令

// Analyze system boot-up performance
systemd-analyze  verify  ${file}

6. 后记

写完这篇文章, 突然感觉, linux 已经不是印象中的linux了, 所有的东西都被systemctl 管理了, 包括device, path, swap, time, mount 等等等等 ,所以还是要与时俱进呀

相关文章

网友评论

      本文标题:俯观 systemd 系统

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