如何使用 Systemctl 管理服务

系统 Linux
systemd是一个服务管理器,目前已经成为Linux发行版的新标准。它使管理服务器变得更加容易。了解并利用组成systemd的工具将有助于我们更好地理解它提供的便利性。

[[388016]]

本文转载自微信公众号「Linux开发那些事儿 」,作者LinuxThings。转载本文请联系Linux开发那些事儿公众号。

systemd是一个服务管理器,目前已经成为Linux发行版的新标准。它使管理服务器变得更加容易。了解并利用组成systemd的工具将有助于我们更好地理解它提供的便利性。

systemctl 的由来

在 centos7 以前使用 service 来管理服务的,虽然它使用起来比较简单,但是对于每一个服务,都需要我们人为的编写脚本来控制服务的启动、停止、重启等,服务控制得好坏,完全依赖于编写脚本的人,而且有些脚本会很长,需要自己处理的情况比较多

比如 /etc/init.d/network 是管理网络服务的脚本,它有250行,而且脚本中逻辑处理还是挺复杂的

为了解决上述的问题,在 centos7 中引入了systemctl服务管理的工具,它使用固定格式的脚本来控制服务的启停,所以,引入systemctl之后,服务的管理变得非常简单了,服务的启动、停止、重启只需要一条命令就可以

下面介绍下如何使用systemctl 来管理服务的

开机启动

对于支持 systemd 的软件,安装的时候,它会自动的在 /usr/lib/systemd/system 目录添加一个配置文件

下面以mysql为例来说明如何设置开机启动

  1. systemctl enable mysqld 

执行上面的命令之后,在 /etc/systemd/system/multi-user.target.wants 目录下添加一个符号链接,这个链接指向/usr/lib/systemd/system/ 里面的 mysqld.service 文件

设置开机启动后,需要等下一次开机的时候,才会自动执行 /etc/systemd/system/ 目录中的文件

如果忘记了一个服务有没有设置成开机启动,可以使用 systemctl is-enabled 服务名 来查看

  1. [root@ecs-centos-7 ~]# systemctl is-enabled mysqld 
  2. enabled 

启动服务

执行 systemctl start 服务名 可以启动服务,下面还是以mysql为例来说明

  1. systemctl start mysqld 

服务启动之后,可以执行 systemctl status 服务名 来检查服务是否启动成功

  1. [root@ecs-centos-7 ~]# systemctl status mysqld 
  2. ● mysqld.service - MySQL Server 
  3.    Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled) 
  4.    Active: active (running) since 五 2020-12-04 21:51:53 CST; 3 months 9 days ago 
  5.      Docs: man:mysqld(8) 
  6.            http://dev.mysql.com/doc/refman/en/using-systemd.html 
  7.  Main PID: 1053 (mysqld) 
  8.    CGroup: /system.slice/mysqld.service 
  9.            └─1053 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid 
  10.  
  11. 12月 04 21:51:51 ecs-centos-7.4-64bit-20200212 systemd[1]: Starting MySQL Server... 
  12. 12月 04 21:51:53 ecs-centos-7.4-64bit-20200212 systemd[1]: Started MySQL Server. 

上面结果中各个字段含义

  1. Loaded: 配置文件的位置, 这里是 /usr/lib/systemd/system/mysqld.service 
  2.  
  3. Active:状态,active (running) 表示启动,如果是 inactive (dead) 表示已关闭 
  4.  
  5. Docs: 服务器文档 
  6.  
  7. Main PID:主进程ID 
  8.  
  9. CGroup:进程组中所有子进程 

除了使用 systemctl status 服务名 之外,还可以使用以下的命令来查看服务的状态

  1. [root@ecs-centos-7 ~]# systemctl is-active mysqld 
  2. active 
  3. [root@ecs-centos-7 ~]# systemctl stop mysqld 
  4. [root@ecs-centos-7 ~]# systemctl is-active mysqld 
  5. inactive 

上面例子中,mysql 一开始是启动的,所以执行 systemctl is-active mysqld 命令显示 active, 表示mysql处于开启状态

当关闭 mysql 服务之后,执行 systemctl is-active mysqld 命令显示 inactive 表示mysql处于关闭状态

停止服务

要停止正在运行的服务,执行 systemctl stop 服务名 命令

  1. systemctl stop mysqld 

如果想直接重启服务的话,执行 systemctl restart 服务名 命令

  1. systemctl restart mysqld 

服务的配置文件

上面查看 mysqld 的状态的时候知道,它的配置文件位于 /usr/lib/systemd/system/mysqld.service,其他的服务配置文件也是位于此目录下,只不过具体的文件名不一样

服务是根据它的配置来启动和停止的,我们使用编辑器或者使用 systemctl cat 服务名 查看服务的配置文件, 下面我们以 sshd 服务的配置文件来说明

  1. [root@ecs-centos-7 ~]# systemctl cat sshd 
  2. # /usr/lib/systemd/system/sshd.service 
  3. [Unit] 
  4. Description=OpenSSH server daemon 
  5. Documentation=man:sshd(8) man:sshd_config(5) 
  6. After=network.target sshd-keygen.service 
  7. Wants=sshd-keygen.service 
  8.  
  9. [Service] 
  10. Type=notify 
  11. EnvironmentFile=/etc/sysconfig/sshd 
  12. ExecStart=/usr/sbin/sshd -D $OPTIONS 
  13. ExecReload=/bin/kill -HUP $MAINPID 
  14. KillMode=process 
  15. Restart=on-failure 
  16. RestartSec=42s 
  17.  
  18. [Install] 
  19. WantedBy=multi-user.target 

配置文件字段说明

  • Unit:启动顺序单元的依赖关系
  1. Description: 服务描述,描述服务的一段文字 
  2.  
  3. Documentation: 服务的文档位置 
  4.  
  5. After:  当前服务在指定的服务之后启动,这里表示 sshd 服务需要在 network 和 
  6.  
  7.         sshd-keygen 服务启动之后再启动 
  8.  
  9.         如果 sshd 服务需要在指定服务启动之前启动的话,使用 Before 字段 
  10.  
  11.  
  12. Wants: 服务的依赖,这种依赖是一种弱依赖关系,在这里表示的是 sshd 和 sshd-keygen  
  13.  
  14.         存在依赖关系,但是它们之间是一种弱依赖 
  15.  
  16.         也就是说,如果 sshd-keygen 启动失败了,是不会影响 sshd 的 
  17.  
  18.         如果要表示强依赖关闭,使用 Requires 字段,也即 如果 sshd-keygen 启动失败 或者退出了,sshd 也必须退出 
  • Service:服务的启动命令以及启动参数
  1. Type:  启动类型,常用的值如下所示 
  2.  
  3.        - simple     默认值,ExecStart字段启动的进程为主进程 
  4.         
  5.        - forking    ExecStart字段将以fork()方式启动,此时父进程将会退出,子进程将成为主进程 
  6.         
  7.        - notify     类似于simple,启动结束后会发出通知信号,然后 Systemd 再启动其他服务 
  8.  
  9.  
  10. EnvironmentFile:服务的环境变量文件,当前配置文件可以用 $KEY 的方式引用环境变量文件中的参数 
  11.  
  12.                 上面的例子中,sshd 的环境变量文件是 /etc/sysconfig/sshd 
  13.                  
  14.  
  15. ExecStart: 启动服务执行的命令 
  16.  
  17. ExecReload:重启服务执行的命令 
  18.  
  19. KillMode:如何停止服务,可能的值有 
  20.  
  21.         - control-group     默认值,当前的控制组里面的所有进程都会被杀掉 
  22.          
  23.         - process           只杀主进程 
  24.          
  25.         - mixed             主进程将收到 SIGTERM 信号,子进程收到 SIGKILL 信号 
  26.          
  27.         - 没有进程会被杀掉,只是执行服务的 stop 命令 
  28.          
  29.  
  30. Restart:服务因为何种原因退出才会重启服务,可能的值有 
  31.  
  32.         - always       不论服务因为何种情况退出,总是重启 
  33.          
  34.         - on-success   正常退出时 
  35.          
  36.         - on-failure   非常正常退出时 
  37.          
  38.         - on-abnormal  被信号终止和超时时,才重启 
  39.          
  40.         - on-abort     只在收到了没有捕捉的信号时,才重启 
  41.          
  42.         - on-watchdog   超时退出,才重启 
  43.  
  44.         大部分的情况下,设置为 on-failure 就可以了 
  45.  
  46.  
  47. RestartSec: 服务器重启前需等待多少秒 
  • Install:如何安装配置文件,也即定义如何做到开机启动

WantedBy 字段表示服务所在的 Target, 这里的 Target 可以理解成一组服务

WantedBy 的值是一个或多个 Targe, 当前 Unit(单元) 激活时(enable)符号链接会放入/etc/systemd/system 目录下面以 Target 名 + .wants 后缀构成的子目录中

比如:sshd 的 WantedBy 字段值是 multi-user.target, 执行 systemctl enable sshd 之后

相当于执行了 ln -s /usr/lib/systemd/system/sshd.service /etc/systemd/system/multi-user.target.wants/sshd.service 命令

与之对应的,当执行 systemctl disable sshd 命令之后,会去掉上图中两个目录之间的符号链接,相当于开机不会启动 sshd 服务

关于上图中配置文件名 sshd.service 的后缀 .service 表示Unit(单元)的种类,如果省略,默认的后缀是 .service ,所以 sshd 会被当做 sshd.service

重新加载配置

如果修改了服务的配置文件,需要重新加载配置文件,然后重启服务

  1. [root@ecs-centos-7 ~]# systemctl daemon-reload 
  2. [root@ecs-centos-7 ~]# systemctl restart mysqld 

救援模式

当出现系统无法正常引导的情况时,可以将系统置于救援模式。救援模式提供了用于修复系统问题的单用户界面。执行 systemctl rescue 命令可以进入救援模式

  1. [root@cghost21 ~]# systemctl rescue 
  2. PolicyKit daemon disconnected from the bus. 
  3. We are no longer a registered authentication agent. 
  4.  
  5. Broadcast message from root@cghost21 on pts/1 (Tue 2021-03-10 20:47:51 CST): 
  6.  
  7. The system is going down to rescue mode NOW! 

进入救援模式之后,当前登陆的其他用户会收到一条系统将进入救援模式的通知

如下示例所示,上面 root 用户执行了 systemctl rescue 命令,test 用户收到了如下系统的广播通知

  1. [test@cghost21 ~]$  
  2. Broadcast message from root@cghost21 on pts/1 (Tue 2021-03-10 20:47:51 CST): 
  3.  
  4. The system is going down to rescue mode NOW! 

 

责任编辑:武晓燕 来源: Linux开发那些事儿
相关推荐

2021-01-31 10:48:24

命令Systemctl工具

2020-11-04 18:53:07

Linuxsystemctl运维

2018-11-19 09:50:51

Linux命令操作系统

2012-05-22 15:19:55

Rex服务器管理

2012-08-09 16:37:45

服务器管理Rex

2009-05-25 17:48:16

IT服务管理

2020-10-16 18:16:21

远程服务器终端开发人员

2020-06-03 09:00:20

firewall-cm网络服务系统运维

2013-12-09 16:15:08

系统管理员WebminLinux服务

2012-06-29 17:46:41

BMCIT服务管理SaaS

2012-07-31 17:24:50

Java管理Linux服务器

2013-12-03 11:01:41

Linux服务器管理Webmin

2011-06-16 10:52:10

SUSE管理器Linux

2010-12-28 17:13:32

管理服务器

2019-12-24 09:39:06

Kubernetes工具微服务

2019-04-24 18:00:57

Linuxsgdisk命令管理分区

2023-04-10 07:23:24

软件微服务网络

2021-06-29 10:50:40

Linux.NET命令

2015-07-31 10:20:13

Linux命令完全指南

2010-07-20 09:13:55

Telnet服务器
点赞
收藏

51CTO技术栈公众号