Systemd相关用法
2017-09-08 本文已影响0人
不知岁月惜
概述:
CentOS 6和之前版本采用SysVinit的系统启动进程管理体系,一般用户都可通过在/etc/inittab文件的配置,来个性化自己的系统启动序列。但也经常会由于特殊环境的硬件等关系问题,造成其串行的启动进程控制流,因为可能任务的阻塞而影响启动过程。
CentOS 7开始使用Systemd,所以我们必须要了解Systemd.本章将从CentOS 7 的启动流程、Unit、服务管理,启动排错,破解口令以及修复grub2 等方面来介绍Systemd的相关内容。
CentOS6与CentOS7上对服务的管理方式对比总结
systemd:
一、启动流程
POST –> Boot Sequence –> Bootloader –> kernel + initramfs(initrd) –> rootfs(根切换)
–> /sbin/init
init:
init:CentOS 5: SysVinit;
CentOS 6: Upstart;
CentOS 7: Systemd;
Systemd:
系统启动和服务器守护进程管理器,负责在系统启动或运行时,激活系统资源,服务器进程和其它进程;
Systemd新特性
系统引导时实现服务并行启动;
按需启动守护进程;
自动化的服务依赖关系管理;
同时采用socket式与D-Bus总线式激活服务;
系统状态快照。
二、核心概念:unit
unit由其相关配置文件进行标识,识别和配置;文件中主要包含了系统服务,监听的socket,保存的快照
以及其他的与init相关的信息;这些配置文件主要保在/usr/lib/systemd/system,
/run/systemd/system,/etc/systemd/system
配置文件:
/usr/lib/systemd/system:每个服务最主要的启动脚本设置,类似于之前的/etc/init.d/
/run/systemd/system:系统执行过程中所产生的服务脚本,比上面目录优先运行
/etc/systemd/system:管理员建立的执行脚本,类似与/etc/rc.d/rcN.d/Sxx类的功能,比上
面目录优先运行
unit的常见类型:
Systemctl –t help 查看unit类型;
Service unit:文件扩展名为.service,用于定义系统服务
Target unit:文件扩展名为.target,用于模拟实现"运行级别"
Device unit:文件扩展名为.device,用于定义内核识别的设备;
Mount unit:文件扩展名.mount,用于定义文件系统挂载点;
Socket unit:文件扩展名.socket,用于标识进程间通信用到的socket文件;也可在系统启动时,
延迟启动服务,实现按需启动;
Snapshot unit:文件扩展名.snapshot:用于管理系统快照
Swap unit:文件扩展名.swap:用于标识管理swap设备
Automount unit:.automount:文件系统自动挂载点设置
Path unit:.path,用于定义文件系统的一文件或目录;常用于当文件系统变化时,延迟激活服务,
如:spool 目录
关键特性:
基于socket的激活机制:socket与程序分离;
基于bus的激活机制;
基于device的激活机制;
基于path的激活机制;
系统快照:保存个unit的当前状态信息于持久存储设备中;
向后兼容sysv init 脚本;
/etc/init.d/
不兼容:
systemctl的命令是固定不变的;
非由systemd启动的服务,systemctl无法与之通信
三、管理系统服务:
CentOS 7:service类型的unit文件
注意:能兼容早期的服务脚本
systemctl命令:
systemctl – Control the systemd system and service manager
格式为:systemctl [OPTIONS…] COMMAND [NAME…]
命令对比:
启动:service NAME start ===》systemctl start NAME.Sservice
停止:service NAME stop ===》systemctl stop NAME.Sservice
重启:service NAME restart===》systemctl restart NAME.Sservice
状态:service NAME status===》systemctl status NAME.Sservice
条件式重启:service NAME condrestart ===>systemctl try-restart NAME.service
centos 7. 如果服务此前是启动的,就重启,如果没有启动就不管了;
centos 6. 如果服务此前是启动的,就重启,如果没有启动就将它启动
重载或重启服务:systemctl reload-or-restart NAME.service
centos 7 如果没服务支持重载就重载此服务,如果不支持,就重启此服务
重载或条件式重启服务:systemctl reload-or-try-restart NAME.service
centos 7 如果没服务支持重载就重载此服务,如果不支持,就尝试重启此服务
查看某服务当前激活与否的状态:systemctl is-active NAME.service
查看所有已激活的服务:chkconfig –list ====>systemctl list-units –type service(简写为-t)
查看所有的服务:chkconfig –list ====>systemctl list-units –type service –all (简写为-t,-a)
设置服务开机自启:chkoncfig NAME on ====>systemctl enable NAME.service
禁止服务开机自启:chkoncfig NAME off ====>systemctl disable NAME.service
查看某服务是否能开机自启:chkconfig –list NAME ===>systemctl is-enabled NAME.service
禁止某服务设定为开机自启:systenctl mask NAME.service
取消禁止某服务设定为开机自启:systenctl unmask NAME.service
查看服务的依赖关系:systemctl list-dependencies NAME.service
查看所有服务的开机自启状态:systemctl list-unit-files –type service
杀掉进程:
systemctl kill unitname 进程名
列出失败的服务
服务状态:
systemctl list-units –type service –all 显示状态
loaded:Unit配置文件已处理
active(running):一次或多次持续处理的运行
active(exited):成功完成一次性的配置
active(running):运行中,等待一个事件
inactive:不允许
enbled:开机启动
disabled:开机不启动
static:开机不启动,但可被另一个启用的服务激活
管理target units:
unit配置文件:.target
ls /usr/lib/systemd/system/*.target
systemctl list-unit-files –type target –all
查看所有级别:systemcl list-units –type target –all
运行级别:
0====> runlever0.target,poweroff.target
1====> runlever1.target ,recuse.target
2====> runlever2.target, multi-user.target
3====> runlever3.target, multi-user.target
4====> runlever4.target, multi-user.target
5====> runlever4.target , graphical.target
6====> runlever4.target,reboot.target
级别切换: init N ====>systemctl isolate NAME.target
例如:切换到图形界面 :systemctl isolate graphical.target
查看级别:runlevel who -r ===>systemcl list-units –type target
查看所有级别:systemcl list-units –type target –all
注: 只有/lib/systemd/system/*.target 文件中AllowIsolate=yes 才能切换( 修改文件需执行syste
mctl daemon-reload 才能生效)
获取默认运行级别:systemctl get-default
修改默认运行级别:systemctl set-default NAME.target
运行原理其实就是创建和删除软链接文件
切换值紧急救援模式:systemctl rescue(级别1,会执行/etc/rc.d/init)
切换值emergency模式:systemctl emergency(最简洁的模式,)
其他常用命令:
关机:systemctl halt, systemctl poweroff
重启:systemctl reboot
挂载:systemctl suspend
快照:systemctl hibernate
快照并挂起:systemctl hybrid-sleep
service unit file:
相关布尔值,1 、yes 、on 、true 都是开启,0 、no 、off、false
文件通常有三部分组成:
[Unit] :定义与unit类型无关的通用选项;用于提高unit的描述信息,unit行为及依赖关系等;
[Service] :定义与特定类型相关的专业选项;此处为service
[Install] :定义有“systemctl enable”以及“systemctl disable ”命令在实现服务启动和禁用
时用到的一些选项
unit段的常用选项:
Description:描述信息,意义性描述
After:定义unit的启动次序;表示当前unit应该晚于那些unit启动;其功能与before相反
Wants:依赖到的其他units;(弱依赖),被依赖的units无法激活时,当前unit可以激活
Requies:依赖到的其他units;(强依赖),被依赖的units无法激活时,当前unit即无法激活
Conflicts:定义units间的冲突关系;
service段的常用选项:
type:用于定义影响ExecStart及相关参数的功能的unit进程启动类型
类型:
simple:由ExecStart所指明的程序启动起来的服务就是主进程(默认值,这个daemon 主要由Exe
cStart 接的指令串来启动,启动后常驻于内存中)
forking:由ExecStart所指明的程序启动起来的服务生成的一个子进程将成为主进程,启动完成后,
父进程会退出
oneshot:与simple 类似,不过这个程序在工作完毕后就结束了,不会常驻在内存中
dbus:与simple 类似,但这个daemon 必须要在取得一个D-Bus的名称后,才会继续运作. 因此
通常也要同时设定BusNname= 才行
notify:类似于simple,在启动完成后会发送一个通知消息。还需要配合
idle:与simple 类似,要执行这个daemon 必须要所有的工作都顺利执行完毕后才会执行。
这类的daemon 通常是开机到最后才执行即可的服务
nvironmentFile:定义环境配置文件(此文件会在Exer之前读取,并为Exec提供变量)
ExecStart:指明启动unit要运行命令或脚本;ExecStartPre(预运行),ExecStartPost(后运行)
ExecStop:指明停止unit要运行的命令或脚本
Restart:当设定Restart=1 时,则当次daemon 服务意外终止后,会再次自动启动此服务
Install段的常用选项
定义由”systemctl enable”以及”systemctl disable”命令在实现服务启动或禁用时用到的一些选项。
Alias:别名,可使用systemctl command Alias.service
RequiredBy:被哪些units所依赖(强依赖)
WantdBy:被哪些units所依赖(若依赖)
Also:安装本服务的时候还要安装别的相关服务
注意:对于新创建的unit文件,或者修改了的unit文件,要通知systemd重载此配置文件,而后可以选择重启
systemctl daemon-reload
服务Unit文件示例:
vim /etc/systemd/system/bak.service (此路径/usr/lib/systemd/system也可以)
[Unit]
Description=backup /etc
Requires=atd.service
[Service]
Type=simple
ExecStart=/bin/bash -c "echo /testdir/bak.sh|at now"(立即启动)
[Install]
WantedBy=multi-user.target
(mkdir /testdir; vim /testdir/bak.sh:)
#!/bin/bash
cp -a /etc/ /testdir/back-`date %F`/
chmod +x /testdir/bak.sh
systemctl start atd
systemctl daemon-reload
systemctl start bak
CentOS 7引导顺序
1.UEFi 或BIOS 初始化,运行POST开机自检
2.选择启动设备
3.引导装载程序,cetnos 7 是gurb2
4.加载装载程序的配置文件:/etc/grub.d/ /etc/default/grub /boot/grub2/grub.cfg
5.加载initramfs驱动模块
6.加载内核模块
7.内核初始化,centos 7使用systemd代替了init
8.执行initrd.target所有单元,包括挂载/etc/fatab
9.从initramfs根文件系统切换到磁盘根目录
10systemd执行默认target配置,配置文件/etc/systemd/default.target /etc/systemd/system/
11.systemd执行sysinit.target初始化系统以及basic.target准操作系统
12.systemd启动multi-user.target下的本机与服务器服务
13.systemd执行multi-user.target下/etc/rc.d/rc.local
14.systemd执行multi-user.target下的getty.target及登入服务
15.systemd执行graphical需要的服务
设置内核参数
systemd相关操作的实际效果展示
系统启动时,通过修改grub选项中的相关内核参数,实现启动时进入不同的模式(紧急救援模式、
emergency模式)
在启动时,启动菜单项按e键,然后在linux16行后添加:(设置内核参数,只影响当次启动)
systemd.unit=emergency.target emergency模式
或 systemd.unit=rescure.target 紧急救援模式
rescure.target 比emergency 支持更多的功能,例如日志等
四、启动排错
文件系统损坏
先尝试自动修复,失败则进入emergency shell,提示用户修复
在 在/etc/fstab 不存在对应的设备和UUID等一段时间,如不可用,进入emergency shell
在/etc/fstab 不存在对应挂载点systemd尝试创建挂载点,否则提示进入emergency shell.
在/etc/fstab 不正确的挂载选项,提示进入emergency shell
五、系统启动时破解root口令
启动时任意键暂停启动
按e键进入编辑模式
将光标移动linux16开始的行,添加内核参数rd.break
按ctrl-x启动
mount –o remount,rw /sysroot
chroot /sysroot
passwd root
touch /.autorelabel
1
破坏grub,然后进行修复