news 2026/4/9 21:54:44

Linux 服务管理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux 服务管理

systemd 介绍


系统启动管理进程

  • CentOS 5 使用 Sys init 引导系统启动,启动速度最慢,采用串行方式启动,无论进程相互之间有无依赖关系。
  • CentOS 6 使用 Upstart init 引导系统启动,启动速度快一点,有依赖的进程之间依次启动而其他与之没有依赖关系的则并行同步启动。
  • CentOS 7 使用 Systemd 引导系统启动,速度最快,所有进程无论有无依赖关系则都是并行启动(很多时候进程没有真正启动而是只有一个信号或者说是标记而已,在真正利用的时候才会真正启动)。Systemd为了解决上文的问题而诞生。它的目标是,为系统的启动和管理提供一套完整的解决方案。

基本概念

服务:从业务角度来称呼,例如 web 服务,数据库服务。
守护进程(daemon):web 服务器对外提供 web 服务,由 web 相关的进程提供支持。
例如:

# 安装软件包 [root@centos7 ~]# yum install -y httpd # 启动服务 [root@centos7 ~]# systemctl start httpd # 查看进程 [root@centos7 ~]# ps axf|tail ...... 87094 ? Ss 0:00 /usr/sbin/httpd -DFOREGROUND 87096 ? S 0:00 \_ /usr/sbin/httpd -DFOREGROUND 87097 ? Sl 0:00 \_ /usr/sbin/httpd -DFOREGROUND 87098 ? Sl 0:00 \_ /usr/sbin/httpd -DFOREGROUND 87099 ? Sl 0:00 \_ /usr/sbin/httpd -DFOREGROUND

httpd 服务对应的守护进程是87094、87096...

systemd 架构

unit 类型

systemctl 命令用于管理不同类型的系统对象,这些对象称之为units

  • Service unit:用于定义系统服务,文件扩展名为.service,例如httpd.service
  • Socket unit:用于标识进程间通信用的 socket文件,文件扩展名为.socket
  • Target unit:用于模拟实现“运行级别”,文件扩展名为.target
  • Timer unit:用于管理计划任务,文件扩展名为.timer
  • Device unit:用于定义内核识别的设备,文件扩展名为.device
  • Mount unit:用于定义文件系统挂载点,文件扩展名为.mount
  • Snapshot unit:管理系统快照,文件扩展名为.snapshot
  • Swap unit:用于标识swap设备,文件扩展名为.swap
  • Automount unit:文件系统的自动挂载点,文件扩展名为.automount
  • Path unit:用于根据文件系统上特定对象的变化来启动其他服务,文件扩展名为.path
  • Slice unit:用于资源管理,文件扩展名为.slice

查看 unit 列表信息

# 列出状态为loaded units [root@centos7 ~]# systemctl list-units

systemctl list-units命令输出说明:

  • UNIT:服务单元名称。
  • LOAD:systemd是否正确解析了单元的配置并将该单元加载到内存中。
  • ACTIVE:单元的高级别激活状态。此信息表明单元是否已成功启动。
  • SUB:单元的低级别激活状态。此信息指示有关该单元的更多详细信息。信息视单元类型、状态以及单元的执行方式而异。
  • DESCRIPTION:单元的简短描述。
# -t选项查看特定类型unit 清单 [laoma@centos7 ~]$ systemctl list-units -t timer UNIT LOAD ACTIVE SUB DESCRIPTION systemd-tmpfiles-clean.timer loaded active waiting Daily Cleanup of Temporary Directories unbound-anchor.timer loaded active waiting daily update of the root trust anchor for DNSSEC LOAD = Reflects whether the unit definition was properly loaded. ACTIVE = The high-level unit activation state, i.e. generalization of SUB. SUB = The low-level unit activation state, values depend on unit type. 2 loaded units listed. Pass --all to see loaded but inactive units, too. To show all installed unit files use 'systemctl list-unit-files'. # 列出类型为service,状态为active和inactive unit [root@centos7 ~]# systemctl list-units --type service --all # 列出所有unit,包括未loaded的unit [root@centos7 ~]# systemctl list-unit-files # 查看失败的服务 [root@centos7 ~]# systemctl --failed --type service

查看单个 unit 信息

[laoma@centos7 ~]$ systemctl status sshd.service ● sshd.service - OpenSSH server daemon Loaded: loaded (/usr/lib/systemd/system/sshd.service; enabled; vendor preset: enabled) Active: `active` (`running`) since 三 2022-11-09 08:45:45 CST; 5h 50min ago Docs: man:sshd(8) man:sshd_config(5) Main PID: 1167 (sshd) Tasks: 1 CGroup: /system.slice/sshd.service └─1167 /usr/sbin/sshd -D
关键字概述
loaded单元配置文件已处理
active(running)正在运行
active(exited)已成功完成一次性配置
active(waiting)运行中,正在等待事件
inactive不再运行
enabled系统引导时启动
disabled系统引导时不启动
static无法启动,依赖其他单元启动

课后作业

1. 解释systemd作用。
2. 使用systemctl命令查看unit 清单信息。
3. 使用systemctl命令查看特定 unit 信息。

控制系统服务


命令任务
systemctl status UNIT查看单元状态的详细信息。
systemctl stop UNIT在运行中的系统上停止一项服务。
systemctl start UNIT在运行中的系统上启动一项服务。
systemctl restart UNIT在运行中的系统上重新启动一项服务。
systemctl reload UNIT重新加载运行中服务的配置文件。
systemctl mask UNIT禁用服务,使其无法手动启动或在系统引导时启动。
systemctl unmask UNIT使屏蔽的服务变为可用。
systemctl enable UNIT将服务配置为在系统引导时启动。使用 --now 选项也会启动该
服务。
systemctl disable UNIT禁止服务在系统引导时启动。使用 --now 选项也会停止该服务。
# 停止服务 [root@centos7 ~]# systemctl stop sshd.service # 客户端连接测试 [root@centos7 ~]# ssh laoma@centos7 hostname # 启动服务 [root@centos7 ~]# systemctl start sshd.service # 客户端连接测试 [root@centos7 ~]# ssh laoma@centos7 hostname # 重启服务,相当于stop再start [root@centos7 ~]# systemctl restart sshd.service # 重新加载服务,服务对应的主进程不会重启,只会重新加载一次配置文件。 # 一般用于配置文件变动后,重新加载 [root@centos7 ~]# systemctl reload sshd.service # 禁止服务开机自启 [root@centos7 ~]# systemctl disable sshd.service [root@centos7 ~]# systemctl is-enabled sshd disabled # 设置服务开机自启 [root@centos7 ~]# systemctl enable sshd.service [root@centos7 ~]# systemctl is-enabled sshd enabled # 禁用服务:服务被禁用后,将无法start,因为服务的配置文件指向/dev/null [root@centos7 ~]# systemctl mask sshd.service # 取消禁用 [root@centos7 ~]# systemctl unmask sshd.service

unit 配置文件


unit 配置文件存放在多个位置:

  • /etc /systemd/system/unit.service,优先生效。一般是管理员自定义的配置。
  • /usr/lib /systemd/system/unit.service,其次生效。软件包自带的默认配置。

配置文件说明

示例单元文件 /usr/lib/systemd/system/sshd.service 说明

# 标识该部分为 Unit 配置,用于描述服务的基本信息、依赖关系等。 [Unit] # 服务的描述信息,说明这是 "OpenSSH 服务器守护进程",便于管理员识别服务用 途。 Description=OpenSSH server daemon # 指定服务的文档路径,这里指向 sshd 命令的手册页(man 8 sshd)和配置文件的手 册页(man 5 sshd_config),方便用户查阅帮助。 Documentation=man:sshd(8) man:sshd_config(5) # 定义服务的启动顺序:sshd 服务必须在 network.target(网络服务就绪)和 sshd-keygen.service(SSH 密钥生成服务)之后启动,确保依赖的资源已准备好。 After=network.target sshd-keygen.service # 表示 sshd 服务 "希望" sshd-keygen.service 运行(但不是强制依赖)。如果 sshd-keygen.service 启动失败,sshd 仍会尝试启动(通常用于生成初始 SSH 密 钥,若密钥已存在则不影响)。 Wants=sshd-keygen.service # 标识该部分为 Service 配置,用于定义服务的启动方式、执行命令、重启策略等。 [Service] # 定义服务的类型为 notify:表示服务启动后会主动通知 systemd 自己已就绪(通过 sd_notify() 函数),systemd 会等待这个通知后再继续后续流程,确保服务真正可 用。 Type=notify # 指定环境变量文件的路径,/etc/sysconfig/sshd 中通常定义 OPTIONS 等变量(如 额外的 sshd 启动参数),这些变量会被后续的 ExecStart 引用。 EnvironmentFile=/etc/sysconfig/sshd # 服务启动时执行的命令: ExecStart=/usr/sbin/sshd -D $OPTIONS # /usr/sbin/sshd:sshd 守护进程的可执行文件路径。 # -D:表示 sshd 以非守护进程模式运行(前台运行),因为 systemd 通常管理前台 进程,便于监控。 # $OPTIONS:引用 EnvironmentFile 中定义的额外参数(如 -p 2222 指定端口)。 # 服务重载配置时执行的命令: ExecReload=/bin/kill -HUP $MAINPID # kill -HUP 发送 SIGHUP 信号给 sshd 主进程,使其重新加载配置文件(无需重启 服务)。 # $MAINPID 是 systemd 自动维护的服务主进程 ID。 # 定义服务停止时的杀死模式:process 表示只杀死服务的主进程(sshd 主进程), 其子进程(如已建立的 SSH 连接)会被保留(避免强制中断现有连接)。 KillMode=process # 定义服务的重启策略:当服务因非正常退出(如崩溃、信号终止)时,systemd 会自 动重启服务;正常退出(如主动停止)则不重启。 Restart=on-failure # 服务重启前的等待时间,这里设置为 42 秒,避免频繁重启导致资源耗尽。 RestartSec=42s # 标识该部分为 Install 配置,用于定义服务如何被 "启用"(即系统启动时自动运 行)。 [Install] # 表示当系统启动到 multi-user.target(多用户命令行模式,非图形界面)时,该服 务会被自动启动。这是服务器的默认运行级别,确保 SSH 服务在系统启动后可用。 WantedBy=multi-user.target

开发一个 study 服务

1. 开发 studyd 服务主程序 study
脚本说明:这是一个无限循环的脚本,每 5 秒会向 /var/log/study.log 文件中追加一行
包含当前时间的日志,内容为 [时间]: I'M studying [ Linux ] 。

[root@centos7 ~ 16:15:19]# vim /usr/bin/study
#!/bin/bash # 第一行内容是脚本的 "解释器声明"(shebang),指定该脚本使用 /bin/bash 作为解释器执行。系统会根据这一行找到对应的 shell 程序来解析后续命令。 # 启动一个无限循环:while 是循环关键字,true 是一个永远为真的条件,因此 这个循环会一直执行下去,直到被外部终止(如 Ctrl+C)。 while true # 循环体的开始标记,do 和后面的 done 之间的内容是循环中重复执行的命令。 do # 执行 date 命令(获取当前系统时间),并通过 $(...) 捕获其输出,将结果 赋值给变量 DATE。 DATE=$(date) # echo 命令输出字符串,其中 $DATE 会被替换为变量的值 # >> 是追加重定向符号,将输出内容追加到 /var/log/study.log 文件中 # 最终输出内容类似 Fri Oct 31 10:00:00 CST 2025: I'M studying [ Linux ]。 echo "$DATE: I'M studying [ Linux ]" >> /var/log/study.log # 让脚本暂停执行 5 秒(sleep 命令用于延迟,单位默认为秒),避免循环执 行过快。 sleep 5 # 循环体的结束标记,与前面的 while 和 do 配合,标志着一次循环的结束。 done
[root@centos7 ~ 16:24:17]# chmod +x /usr/bin/study

2. 创建 studyd 服务单元文件

# 参考 sshd.service [root@centos7 ~ 16:25:51]# cp /usr/lib/systemd/system/sshd.service \ /etc/systemd/system/studyd.service [root@centos7 ~ 16:26:32]# vim /etc/systemd/system/studyd.service
[Unit] Description=study server daemon [Service] ExecStart=/usr/bin/study [Install] WantedBy=multi-user.target
# 通知 systemd 读取 unit 变化 [root@centos7 ~ 16:26:36]# systemctl daemon-reload # 启用并启动服务 [root@centos7 ~ 16:28:29]# systemctl enable studyd --now # 查看服务状态 [root@centos7 ~ 16:28:34]# systemctl status studyd ● studyd.service - study server daemon Loaded: loaded (/etc/systemd/system/studyd.service; enabled; vendor preset: disabled) Active: `active (running)`` since 五 2025-10-31 16:28:34 CST; 1s ago Main PID: 2786 (study) Tasks: 2 CGroup: /system.slice/studyd.service ├─2786 /bin/bash /usr/bin/study └─2788 sleep 5 10月 31 16:28:34 centos7.laoma.cloud systemd[1]: Started study server daemon.

3. 验证日志

[root@centos7 ~ 16:28:36]# tail -f /var/log/study.log 2025年 10月 31日 星期五 16:28:29 CST: I'M studying [ Linux ] 2025年 10月 31日 星期五 16:28:34 CST: I'M studying [ Linux ] 2025年 10月 31日 星期五 16:28:39 CST: I'M studying [ Linux ] 2025年 10月 31日 星期五 16:28:44 CST: I'M studying [ Linux ] 2025年 10月 31日 星期五 16:28:49 CST: I'M studying [ Linux ] 2025年 10月 31日 星期五 16:28:54 CST: I'M studying [ Linux ] ......

课后作业


以 sshd 服务为例
1. 如何启停服务?
2. 如何重启和重新加载服务,这两者的区别是什么?
3. 如何启用和禁用服务开机自启?
4. 如何禁用服务和取消禁用服务?
5. 如何查看服务依赖和反依赖?

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/4 3:16:11

香港科技大学突破性研究:让AI像指挥乐团一样看懂长视频

这项由香港科技大学刘润涛、刘子艺、唐嘉琦、马悦、皮仁杰、张季鹏和陈启峰等研究团队共同完成的研究于2025年12月发表在arXiv预印本平台上,论文编号为arXiv:2512.20618v1。有兴趣深入了解的读者可以通过该编号查询完整论文。当我们坐在电视机前观看一部两小时的电影…

作者头像 李华
网站建设 2026/4/2 7:26:12

13123123

1231231231

作者头像 李华
网站建设 2026/4/8 18:34:11

同城代驾系统的安全架构设计

温馨提示:文末有资源获取方式~一、项目背景同城代驾,用户可以呼叫代驾司机,也可以自己注册成为代驾司机进行接单办公。平台提供代驾服务,每天有大量代驾订单更新,用户可根据需求抢单或使用自动抢单功能。严格审核代驾司…

作者头像 李华
网站建设 2026/3/22 13:36:02

Open-AutoGLM挂虚拟机的3大前提条件,少一个都可能失败

第一章:Open-AutoGLM可以挂虚拟机吗Open-AutoGLM 作为一款基于大语言模型的自动化任务处理框架,支持在多种环境中部署运行,包括物理机、容器以及虚拟机。将其部署在虚拟机中不仅可以实现资源隔离,还能灵活扩展和迁移,适…

作者头像 李华