写点什么

centos7 的启动流程(systemctl)

  • 2022 年 5 月 05 日
  • 本文字数:3636 字

    阅读完需:约 12 分钟

chkconfig sshd –list ==> ls /etc/systemd/system/*.wants/sshd.service


查看服务是否开机自启


systemctl is-enabled name.service


查看服务的依赖关系


systemctl list-dependencies name.service


杀掉进程


systemctl kill unitname


[](()3.服务状态




systemctl list-unit-files --type service --all 显示状态


loaded Unit 配置文件已处理


active(running) 一次或多次持续处理的运行


active(exited) 成功完成一次性的配置


active(waiting) 运行中,等待一个事件


inactive 不运行


enabled 开机启动


disabled 开机不启动


static 开机不启动,但可被另一个启用的服务激活


[](()4.例子




显示所有单元状态


systemctl 或 systemctl list-units


只显示服务单元的状态


systemctl --type=service


显示 sshd 服务单元


systemctl –l status sshd.service


验证 sshd 服务当前是否活动


systemctl is-active sshd


启动,停止和重启 sshd 服务


systemctl start sshd.service


systemctl stop sshd.service


systemctl restart sshd.service


重新加载配置


systemctl reload sshd.service


列出活动状态的所有服务单元


systemctl list-units --type=service


列出所有服务单元


systemctl list-units --type=service --all


查看服务单元的启用和禁用状态


systemctl list-unit-files --type=service


列出失败的服务


systemctl --failed --type=service


列出依赖的单元


systemctl list-dependencies sshd


验证 sshd 服务是否开机启动


systemctl is-enabled sshd


禁用 network,使之不能自动启动,但手动可以


systemctl disable network


启用 network


systemctl enable network


禁用 network,使之不能手动或自动启动


systemctl mask network


启用 network


systemctl unmask network


[](()三. service unit 文件格式


======================================================================================


/etc/systemd/system 系统管理员和用户使用


/usr/lib/systemd/system:发行版打包者使用(一般是参考官方文档写的)


以 “#” 开头的行后面的内容会被认为是注释


相关布尔值,


1、yes、on、true 都是开启


0、no、off、false 都是关闭


时间单位默认是秒,所以要用毫秒(ms)分钟(m)等须显式说明


service unit file 文件通常由三部分组成:


[Unit]:定义与 Unit 类型无关的通用选项;用于提供 unit 的描述信息、unit 行


为及依赖关系等


[Service]:与特定类型相关的专用选项;此处为 Service 类型


[Install]:定义由“systemctl enable”以及"systemctl disable“命令在实现服务启用或禁用时用到的一些选项

[](()1. Unit 段的常用选项:

Description:描述信息


After:定义 unit 的启动次序,表示当前 unit 应该晚于哪些 unit 启动,其功能与 Before 相反


Requires:依赖到的其它 units,强依赖,被依赖的 units 无法激活时,当前 unit 也无法激活


Wants:依赖到的其它 units,弱依赖


Conflicts:定义 units 间的冲突关系


例如:firewalld 和 iptables 服务(冲突关系)

[](()2. Service 段的常用选项:

Type:定义影响 ExecStart 及相关参数的功能的 unit 进程启动类型


? simple:默认值,这个 daemon 主要由 ExecStart 接的指令串来启动,启动后常


驻于内存中


? forking:由 ExecStart 启动的程序透过 spawns 延伸出其他子程序来作为此


daemon 的主要服务。原生父程序在启动结束后就会终止


? oneshot:与 simple 类似,不过这个程序在工作完毕后就结束了,不会常驻在内存中


? dbus:与 simple 类似,但这个 daemon 必须要在取得一个 D-Bus 的名称后,才


会继续运作.因此通常也要同时设定 BusNname= 才行


? notify:在启动完成后会发送一个通知消息。还需要配合 NotifyAccess 来让


Systemd 接收消息


? idle:与 simple 类似,要执行这个 daemon 必须要所有的工作都顺利执行完毕后才会执行。这类的 daemon 通常是开机到最后才执行即可的服务


EnvironmentFile:环境配置文件


ExecStart:指明启动 unit 要运行命令或脚本的绝对路径


ExecStartPre: ExecStart 前运行


ExecStartPost: ExecStart 后运行


ExecStop:指明停止 unit 要运行的命令或脚本


Restart:当设定 Restart=1 时,则当次 daemon 服务意外终止后,会再次自动启动此服务

[](()3. Install 段的常用选项:

? Alias:别名,可使用 systemctl command Alias.service


? RequiredBy:被哪些 units 所依赖,强依赖


? WantedBy:被哪些 units 所依赖,弱依赖


? Also:安装本服务的时 《一线大厂 Java 面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 候还要安装别的相关服务


注意:对于新创建的 unit 文件,或者修改了的 unit 文件,要通知 systemd 重载此


配置文件,而后可以选择重启systemctl daemon-reload


示例写一个备份服务(用于打包)


写成脚本:用于将/etc/下面的文件打包备份


touch /data/bak.tar


tar cf /data/etc.tar /etc/ &>/dev/null


加执行权限 chmod +x /data/bak.sh


然后写服务


vim /etc/systemd/system/bak.service


[Unit]


Description=backup /etc


Requires=atd.service 强依赖


[Service]


Type=simple


ExecStart=/bin/bash -c "echo /data/bak.sh|at now" #后面的 at now 计划任务(现在执行一次)


[Install]


WantedBy=multi-user.target


查看自己写的服务文件systemctl list-units -t |grep bak.service


发现没有



启用服务


systemctl daemon-reload 重新加载


systemctl start bak 启用该服务


[](()四. 运行级别


==========================================================================


target units:


unit 配置文件:.target


ls /usr/lib/systemd/system/*.target


systemctl list-unit-files --type target --all


运行级别:


0 ==> runlevel0.target, poweroff.target


1 ==> runlevel1.target, rescue.target


2 ==> runlevel2.target, multi-user.target


3 ==> runlevel3.target, multi-user.target


4 ==> runlevel4.target, multi-user.target


5 ==> runlevel5.target, graphical.target


6 ==> runlevel6.target, reboot.target



查看依赖性:


systemctl list-dependencies graphical.target


级别切换


init N ==> systemctl isolate name.target


例如:


systemctl isolate multi-user.target


注:只有/lib/systemd/system/*.target 文件中 AllowIsolate=yes 才能切换


(修改文件需执行 systemctl daemon-reload 才能生效)


查看 target


runlevel ;who -r


systemctl list-units --type target


获取默认运行级别


/etc/inittab ==> systemctl get-default


修改默认级别/etc/inittab ==> systemctl set-default name.target


systemctl set-default multi-user.target


ls –l /etc/systemd/system/default.target


切换至紧急救援模式:


systemctl rescue


切换至 emergency 模式:


systemctl emergency


其它常用命令:


传统命令 init,poweroff,halt,reboot 都成为


systemctl 的软链接


关机:systemctl halt、systemctl poweroff


重启:systemctl reboot


挂起:systemctl suspend


休眠:systemctl hibernate


休眠并挂起:systemctl hybrid-sleep


[](()1.CentOS 7 引导顺序




1.UEFi 或 BIOS 初始化,运行 POST 开机自检


2.选择启动设备


3.引导装载程序, centos7 是 grub2


4.加载装载程序的配置文件:


/etc/grub.d/


/etc/default/grub 模板文件


/boot/grub2/grub.cfg


/etc/default/grub 更改网卡名字(变成传统的 eth 模式)



在**/boot/grub2/grub.cfg**不能更改


配合 grub2-makconfig 命令(在屏幕上打印)


要怎样写:grub2-mkconfig -o /boot/grub2/grub.cfg


-o 覆盖老的 grub.cfg 文件



也就是说 grub.cfg 文件**被删了


也可以,重新生成


grub2-mkconfig -o /boot/grub2/grub.cfg


5.加载 initramfs 驱动模块


6.加载内核选项


7.内核初始化,centos7 使用 systemd 代替 init


8.执行 initrd.target 所有单元,包括挂载/etc/fstab


9.从 initramfs 根文件系统切换到磁盘根目录


10…systemd 执行默认 target 配置,配置文件/etc/systemd/system/default.target------------>相当于 centos6 的/etc/inittab 中的第一项



11.systemd 执行 sysinit.target 初始化系统及 basic.target(强依赖)准备操作系统


12.systemd 启动 multi-user.target 下的本机与服务器服务


13.systemd 执行 multi-user.targe 的/etc/rc.d/rc.local


14.Systemd 执行 multi-user.target 下的 getty.target 及登录服务


15.systemd 执行 graphical 需要的服务


设置内核参数


设置内核参数,只影响当次启动


启动时,在 linux16 行后添加 systemd.unit=desired.target


systemd.unit=emergency.target


systemd.unit=rescue.target


rescue.target 比 emergency 支持更多的功能,例如日志等


systemctl default 进入默认 target


[](()2.启动排错




文件系统损坏


先尝试自动修复,失败则进入 emergency shell,提示用户修复


在/etc/fstab 不存在对应的设备和 UUID


等一段时间,如不可用,进入 emergency shell


在/etc/fstab 不存在对应挂载点


systemd 尝试创建挂载点,否则提示进入 emergency shell.


在/etc/fstab 不正确的挂载选项


提示进入 emergency shell


[](()3.破解 CentOS7 的 root 口令方法一




启动时任意键暂停启动


按 e 键进入编辑模式


将光标移动 linux16 开始的行,添加内核参数 rd.break


按 ctrl-x 启动


因为/ 状态只读


真正的根为/sysroot

用户头像

还未添加个人签名 2022.04.13 加入

还未添加个人简介

评论

发布
暂无评论
centos7的启动流程(systemctl)_Java_爱好编程进阶_InfoQ写作社区