美文网首页
俯观 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