16 Linux系统服务

一. Linux启动流程

CentOS6启动级别
CentOS6 VS Centos7开机启动流程图解

二. Linux运行级别

1. 什么是运行级别,运行级别就是操作系统当前正在运行的功能级别

System V init运行级别 systemd目标名称 作用
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 重启

2. 如何调整系统启动的运行级别?systemd使用’targets’而不是runlevels。默认情况下,有两个主要目标:

multi-user.target:类似于运行级别3
graphical.target: 类似于运行级别5

image-20200823164842302

#1.查看系统默认运行级别
# ls /usr/lib/systemd/system/runlevel*
[root@student ~]# runlevel(6,7通用)
[root@student ~]# systemctl get-default

#2.要设置默认目标,请运行
[root@student ~]# systemctl set-default graphical.target  # 切换图形界面
[root@student ~]# systemctl set-default multi-user.target # 切换命令界面

三. Linux systemd

1.systemd的由来

Linux一直以来都是采用init进程作为祖宗进程,但是init有两个缺点:
1、启动时间长。Init进程是串行启动,只有前一个进程启动完,才会启动下一个进程。
2、启动脚本复杂,初始化完成后系统会加载很多脚本,脚本都会处理各自的情况,这会让脚本多而复杂。
Centos5 是启动速度最慢的,串行启动过程,无论进程相互之间有无依赖关系。
Centos6 相对启动速度有所改进。有依赖的进程之间依次启动而其他与之没有依赖关系的则并行同步启动。
Centos7 所有进程无论有无依赖关系则都是并行启动(当然很多时候进程没有真正启动而是只有一个信号或者说是标记而已,在真正利用的时候才会真正启动。)
img

2.什么是systemd

systemd即为system daemon守护进程,systemd主要解决上文的问题而诞生,systemd的目标是,为系统的启动和管理提供一套完整的解决方案。

3.systemd的优势

1、最新系统都采用systemd管理(RedHat7,CentOS7,Ubuntu15等)
2、Centos7支持开机并行启动服务,显著提高开机启动效率。
3、Centos7关机只关闭正在运行的服务,而Centos6全部都关闭一次。
4、Centos7服务的启动与停止不在使用脚本进行管理,也就是/etc/init.d下不在有脚本。
5、Centos7使用systemd解决原有模式缺陷,比如原有service不会关闭程序产生的子进程。

3.systemd相关配置文件
/usr/lib/systemd/system/ #类似Centos6系统的启动脚本,/etc/init.d/
/etc/systemd/system/ #类似Centos6系统的/etc/rc.d/rcN.d/
/etc/systemd/system/multi-user.target.wants/,开机要启动的程序

4.systemd管理服务相关命令
systemctl管理服务的启动、重启、停止、重载、查看状态等常用命令

systemctl命令 作用
systemctl start crond.service 启动服务
systemctl stop crond.service 停止服务
systemctl restart crond.service 重启服务
systemctl reload crond.service 重新加载配置
systemctl status crond.servre 查看服务运行状态
systemctl is-active sshd.service 查看服务是否在运行中
systemctl mask crond.servre 禁止服务运行
systemctl unmask crond.servre 取消禁止服务运行
systemctl cat vsftpd 查看启动文件

当我们使用systemctl启动一个守护进程后,可以通过sysytemctl status查看此守护进程的状态

状态 描述
loaded 服务单元的配置文件已经被处理
active(running) 服务持续运行
active(exited) 服务成功完成一次的配置
active(waiting) 服务已经运行但在等待某个事件
inactive 服务没有在运行
enabled 服务设定为开机运行
disabled 服务设定为开机不运行
static 服务开机不启动,但可以被其他服务调用启动

systemctl 设置服务开机启动、不启动、查看各级别下服务启动状态等常用命令

systemctl命令(7系统) 作用
systemctl enable crond.service 开机自动启动
systemctl disable crond.service 开机不自动启动
systemctl list-unit-files 查看各个级别下服务的启动与禁用
systemctl is-enabled crond.service 查看特定服务是否为开机自启动
systemctl daemon-reload 创建新服务文件需要重载变更

CentOS7系统, 管理员可以使用 systemctl 命令来管理服务器启动与停止

# 关机相关命令
systemctl poweroff      # 立即关机,常用
# 重启相关命令
systemctl reboot        # 重启命令,常用

systemctl的journalctl日志

journalctl -n 20    # 查看最后20行
journalctl -f       # 动态查看日志
journalctl -p err   # 查看日志的级别
journalctl -u crond # 查看某个服务的单元的日志
# journalctl -xe
# systemctl status nginx -l

systemcltl 其他

# 1 centos6 中启动服务,centos7启动服务
/etc/init.d/network restart
service network restart  #(只会干掉父进程,不会关掉子进程)
# centos7启动服务
systemctl restart network # 所有服务都放在/usr/lib/systemd/system/ 



# 2 制作系统服务(nginx为例)
# /usr/lib/systemd/system/vsftpd.service
[Unit]
Description=Vsftpd ftp daemon # 描述
After=network.target          # 在XX后启动

[Service]
Type=forking                  # 程序后台运行
ExecStart=/usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf # 命令
# ExecStartPre 启动之前执行
# ExecStop 停止
# ExecRestart 重启
# ExecReload 重新加载
[Install]
WantedBy=multi-user.target  # 在哪个运行级别下

# 3  制作系统服务
# cd /usr/lib/systemd/system/
# vim mynginx.service
[Unit]
Description=my nginx
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecStop=/usr/local/nginx/sbin/nginx -s stop
ExecRestart=/usr/local/nginx/sbin/nginx -s restart
ExecReload=/usr/local/nginx/sbin/nginx -s reload
[Install]
WantedBy=multi-user.target  # 在哪个运行级别下


# Loaded: loaded (/usr/lib/systemd/system/nginx.service; disabled; vendor preset: disabled) 其中的disabled表示没有设置开机自启动, enable表示自启动
chmod 754 mynginx.service
systemctl start mynginx           # 启动nginx
systemctl enable mynginx.service  # 开机启动
systemctl status mynginx.service  # 查看是否成功
systemctl disable mynginx.service # 取消开机启动

四. Linux单用户模式

如何使用单用户模式进行变更系统密码?以Centos7系统为例:(Centos6破解方式请自行百度)

第1步:重启Linux系统主机并出现引导界面时,按下键盘上的e键进入内核编辑界面
img
第2步:在linux16这行的后面添加enforcing=0 init=/bin/bash,然后按下Ctrl + X组合键来运行修改过的内核程序
img第3步:大约5秒过后,进入到系统的单用户模式,依次输入以下命令,等待系统重启操作完毕,然后就可以使用新密码来登录Linux系统了。命令行执行效果如图所示。
img
Centos7单用户破解密码更为详细版

五. Linux下救援模式

场景一:当系统坏了,无法登陆系统,但需要把里面的数据复制出来,怎么办?

步骤一、先挂载光盘,然后选择光盘引导为第一位
img
步骤二、进入故障排除模式–>然后选择救援模式
img
img
步骤三、挂载真实系统后,发现数据都还存在
img

场景二、修复MBR,主要出现在安装双系统时,后安装的系统把原来系统的MBR删除了,需要修复。

步骤一、破坏硬盘的前446字节,模拟MBR引号损坏,会发现重启无法启动系统

[root@m01 ~]# dd if=/dev/zero of=/dev/sda bs=1 count=446

img
步骤二、重启系统,然后按照之前的操作进入救援模式,然后分配一个shell终端,挂载真实的操作系统进行修复
img
步骤二、修复MBR引导,然后重启连接服务器

#1.使用grub修复
# grub2-install /dev/sda

#2.然后退出
# exit

#3.最后重启进入系统
# reboot

场景三、Centos7误删除grub文件如何进行修复。
步骤一、模拟误删故障

#1.删除grub2 
[root@m01 ~]# rm -rf  /boot/grub2 
#2.重启计算机 
[root@m01 ~]# reboot

img
步骤二、重启系统,然后按照之前的操作进入救援模式,然后分配一个shell终端,挂载真实的操作系统进行修复
img
步骤三、使用grub2-install、grub2-mkconfig恢复配置文件
img

PS: 最后别忘记修改 BIOS 引导,让硬盘回归到第一引导

posted @ 2020-09-03 19:37  给你加马桶唱疏通  阅读(146)  评论(0编辑  收藏  举报