Linux启动流程和Systemd特性

2024-08-26 08:04

本文主要是介绍Linux启动流程和Systemd特性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 内核设计流派
  • linux启动流程
    • 1.硬件加电自检
    • 2.启动加载器bootloader
    • 3.加载kernel
    • 4.init初始化
    • 5.用户终端启动
  • systemd
    • systemd特性
    • systemd的unit
      • unit配置文件
    • systemctl管理系统服务service unit
      • 服务状态
    • service unit文件格式
      • Unit段
      • Service段
      • Install段

内核设计流派

1.宏内核(monolithic kernel):又称单内核和强内核,Unix,Linux把所有系统服务都放到内核里,所有功能集成于同一个程序,分层实现不同功能,系统庞大复杂,Linux其实在单内核上实现了模块化,也就相当于吸收了微内核的优点。2.微内核(micro kernel): 简化内核功能,在内核之外的用户态尽可能多地实现系统服务,同时加入相互之间的安全保护,每种功能使用一个单独子系统实现,将内核功能移到用户空间,性能有待商讨。windows,Solaris,Harmonyos等使用微内核

linux启动流程

参考链接:https://s4.51cto.com/wyfs02/M02/87/20/wKiom1fVBELjXsvaAAUkuL83t2Q304.jpg

1.硬件加电自检

POST: Power-On-Self-Test,加电自检,是BIOS功能的一个主要部分。负责完成对CPU、主板、内存、硬盘子系统、显示子系统、串并行接口、键盘等硬件情况的检测。

主板的ROM: BIOS,Basic Input and Output System,保存着有关计算机系统最重要的基本输入输出程序,系统信息设置、开机加电自检程序和系统启动自检程序等。

主板的RAM:CMOS互补金属氧化物半导体,保存各项参数的设定,按次序查找引导设备,第一个有引导程序的设备为本次启动设备。

2.启动加载器bootloader

bootloader:引导加载器,引导程序1.Windows: ntloader,仅是启动OS2.Linux: 功能丰富,提供菜单,允许用户选择要启动系统或不同的内核版本;把用户选定的内核装载到内存中的特定空间中解压、展开,并把系统控制权移交给内核。
Linux的bootloaderLILO: Linux Loader,早期的bootloader,功能单一。GRUB: GRand Unified Bootloader, CentOS5,6 GRUB 0.97:GRUB Legacy,CentOS 7以后使用GRUB 2.02
GRUB启动阶段1.primary boot loader :1st stage: MBR的前446个字节1.5 stage: MBR之后的扇区,让stage1中的bootloader能识别stage2所在的分区上的文件系统2.secondary boot loader : 2nd stage,分区文件/boot/grub/

3.加载kernel

kernel自身初始化过程1.探测可识别到的所有硬件设备2.加载硬件驱动程序(借助于ramdisk加载驱动)3.以只读方式挂载根文件系统4.运行用户空间的第一个应用程序:/sbin/init

4.init初始化

init程序的类型SysV: init, CentOS5之前配置文件:/etc/inittab Upstart: init, CentOS6配置文件:letc/inittab,letch/init/*.confSystemd: systemd, CentOS7配置文件:/usr/lib/systemd/system/etc/systemd/system

运行级别
运行级别:为系统运行或维护等目的而设定;0-6:7个级别,一般使用3,5做为默认级别

运行级别:0:关机1:单用户模式(root自动登录), single,维护模式2:多用户模式,启动网络功能,但不会启动NFS;维护模式3:多用户模式,正常模式;文本界面4:预留级别;可同3级别5:多用户模式,正常模式;图形界面6:重启

切换级别

init num

查看级别

runlevel
who -r

在这里插入图片描述

5.用户终端启动

用户空间应用程序系统实用程序: Linux 提供了大量的系统实用程序,如 ls、cp、mv、grep、find、awk 等,用于文件管理、文本处理和系统监控等。用户应用程序: 包括所有在用户空间运行的应用程序,如文本编辑器(vim、nano)、网络浏览器(Firefox、Chrome)、编译器(gcc)、办公软件等。

systemd

systemd特性

CentOS从7版本之后开始使用systemd实现init进程,目前systemd也被广泛使用在各大linux发行版中,它是Linux的系统和服务管理器,负责在系统启动或运行时,激活系统资源,服务器进程和其它进程。它取代了传统的 SysV init 系统。它的设计目标是提供更高效、更灵活的服务管理,并简化系统启动过程。

systemd特性1.系统引导时实现服务的并行化启动;2.自动化管理服务依赖关系;3.按需启动守护进程;4.同时采用socket式与D-Bus总线式激活服务5.socket与服务程序分离6.向后兼容sysv init脚本7.使用systemctl命令管理,systemctl命令固定不变,不可扩展,非由systemd启动的服务,systemctl无法与之通信和控制8.系统状态快照

systemd的unit

systemd的核心概念:unit

unit表示不同类型的systemd对象,通过配置文件进行标识和配置;文件中主要包含了系统服务、监听socket、保存的系统快照以及其它与init相关的信息。

查看unit类型

systemctl -t help

在这里插入图片描述
在这里插入图片描述

unit配置文件

/usr/lib/systemd/system       每个服务最主要的启动脚本设置,类似于之前的/etc/init.d/
/lib/systemd/system           ubutun的对应目录,兼容于centos7,8和ubuntu  (建议存放此目录)/run/systemd/system           系统执行过程中所产生的服务脚本,比上面目录优先运行
/etc/systemd/system           管理员建立的执行脚本,类似于/etc/rcN.d/Sxx的功能,比上面目录优先运行

rocky系统
在这里插入图片描述
ubuntu系统
在这里插入图片描述
在这里插入图片描述

systemctl管理系统服务service unit

命令:

systemctl COMMAND name.service
systemctl start   name.service       #启动:相当于service name start
systemctl stop    name.service       #停止:相当于service name stop
systemctl restart name.service       #重启:相当于service name restart
systemctl status  name.service       #查看状态:相当于service name statussystemctl mask name.service          #禁止自动和手动启动:
systemctl unmask name.service        #取消禁止systemctl is-active  name.service     #查看某服务当前激活与否的状态
systemctl is-enabled name.service    #查看服务是否开机自启:systemctl cat sshd                   #查看service文件内容systemctl list-units --type| -t service         #查看所有已经激活的服务:
systemctl list-units --type service --all|-a    #查看所有服务:systemctl enable  name.service        #设定某服务开机自启,相当于chkconfig name on
systemctl disable name.service        #设定某服务开机禁止启动:相当于chkconfig name offsystemctl list-unit-fi1es --type service    #查看所有服务的开机自启状态,相当于chkconfig --listls /etc/systemd/system/*.wants/name.service    #用来列出该服务在哪些运行级别下启用和禁用: chkconfig -list namesystemctl --failed --type=service      #列出失败的服务#开机并立即启动或停止
systemctl enable --now postfix
systemctl disable --now postfix #查看服务的依赖关系:
systemctl list-dependencies name.service#杀掉进程:
systemctl kill unitname

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

服务状态

显示状态

systemctl list-unit-files --type service --all
显示状态1.loaded            Unit配置文件已处理2.active(running)   一次或多次持续处理的运行3.active(exited)    成功完成─次性的配置4.active(waiting)   运行中,等待一个事件5.inactive          不运行6.enabled           开机启动7.disabled          开机不启动8.static            开机不启动,但可被另一个启用的服务激活9.indirect          重定向到别处

在这里插入图片描述

service unit文件格式

/etc/systemd/system:系统管理员和用户使用
/usr/liblsystemd/system:发行版打包者使用

帮助中文手册:https://www.jinbuguo.com/systemd/systemd.service.html

在这里插入图片描述

unit格式说明:·以"#"开头的行后面的内容会被认为是注释·相关布尔值,1、yes、on、true都是开启,0、no、off、false都是关闭·时间单位默认是秒,所以要用毫秒(ms)分钟(m)等须显式说明
service unit file文件通常由三部分组成:[Unit]: 定义与Unit类型无关的通用选项;用于提供unit的描述信息、unit行为及依赖关系等[Service]: 与特定类型相关的专用选项;此处为Service类型[Instally]: 定义由"systemctl enable"以及"systemctl disable"命令在实现服务启用或禁用时用到的一些选项

Unit段

Unit段的常用选项:Description: 描述信息After: 定义unit的启动次序,表示当前unit应该晚于哪些unit启动,其功能与Before相反Requires: 依赖到的其它units,强依赖,被依赖的units无法激活时,当前unit也无法激活Wants: 依赖到的其它units,弱依赖Conflicts: 定义units间的冲突关系
[root@rocky ~]# head -n 5 /lib/systemd/system/postfix.service 
[Unit]
Description=Postfix Mail Transport Agent
After=syslog.target network.target
Conflicts=sendmail.service exim.service

Service段

Service段的常用选项:1.Type:定义影响ExecStart及相关参数的功能的unit进程启动类型1.1 simple:默认值,这个daemon主要由ExecStart接的指令串来启动,启动后常驻于内存中1.2 forking:由ExecStart启动的程序透过spawns延伸出其他子程序来作为此daemon的主要服务。原生父程序在启动结束后就会终止1.3 oneshot: 与simple类似,不过这个程序在工作完毕后就结束了,不会常驻在内存中1.4 dbus: 与simple类似,但这个daemon必须要在取得一个D-Bus的名称后,才会继续运作.因此通常也要同时设定BusNname= 才行1.5 notify:在启动完成后会发送一个通知消息。还需要配合NotifyAccess来让Systemd接收消息1.6 idle:与simple类似,要执行这个daemon必须要所有的工作都顺利执行完毕后才会执行。这类的daemon通常是开机到最后才执行即可的服务2.EnvironmentFile: 环境配置文件3.ExecStart: 指明启动unit要运行命令或脚本的绝对路径ExecStartPre: ExecStart前运行4.ExecStartPost: ExecStart后运行5.ExecStop: 指明停止unit要运行的命令或脚本6.Restart: 当设定Restart=1时,则当次daemon服务意外终止后,会再次自动启动此服务7.RestartSec: 设置在重启服务(Restart=)前暂停多长时间。默认值是100毫秒(100ms)。如果未指定时间单位,那么将视为以秒为单位。例如设为"20"等价于设为"20s""。8.PrivateTmp:设定为yes时,会在生成/tmp/systemd-private-UUID-NAME.service-xXxxXX/tmp/目录

Install段

lnstall段的常用选项:
· Alias: 别名,可使用systemctl command Alias.service
· RequiredBy: 被哪些units所依赖,强依赖
. WantedBy: 被哪些units所依赖,弱依赖
. Also: 安装本服务的时候还要安装别的相关服务

注意:对于新创建的unit文件,或者修改了的unit文件,要通知systemd重载此配置文件;而后可以选择重启

systemctl daemon-reload

这篇关于Linux启动流程和Systemd特性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1108006

相关文章

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理