目录
1.2 在日常的运维过程中,是否会遇到机器出现问题启动不了?
2.2.9 运行 /etc/systemd/system/multi-user.target.wants/ 下的服务
2.2.10 运行 /etc/rc.local 以及 /etc/fstab文件
开机启动流程
1.自己的机房 --》自建机房 --》大量的物理机器 --》真实的服务器 --》成本高
2.大量的云服务器 --》阿里云,腾讯云,aws,华为云等,成本低,性价比高
1.掌握让某个软件或服务开机自动运行的方法
2.开机不能正常启动,是什么原因,或者那个环节出现了问题
3.防止黑客植入木马,去查询黑客会把木马放到哪些地方?
##############################################
##############################################
开机自检 :上电自检(POST, Power On Self Test)
谁去检查?
由主板上面的BIOS程序去完成,BIOS(Basic Input Output System)程序,基本输入输出系统。
自检什么东西?
对CPU、系统主板、基本内存、扩展内存、系统ROM BIOS等器件的测试。如发现错误,给操作者提示或警告。简化或加快该过程,可使系统能够快速启动。
电脑里有哪些基本的硬件?
主板(motherboard)、cpu、内存,磁盘,网卡,显卡,声卡,电源,鼠标,键盘、显示器等
##############################################
BIOS程序:
BIOS是个人电脑启动时加载的第一个软件。
它是一组固化到计算机内主板上一个ROM芯片上的程序,它保存着计算机最重要的基本输入输出的程序、开机后自检程序和系统自启动程序,它可从CMOS中读写系统设置的具体信息。 其主要功能是为计算机提供最底层的、最直接的硬件设置和控制。此外,BIOS还向作业系统提供一些系统参数。系统硬件的变化是由BIOS隐藏,程序使用BIOS功能而不是直接控制硬件。现代作业系统会忽略BIOS提供的抽象层并直接控制硬件组件。
ROM存储器 : read only memory --》只读的存储器 断电信息丢失
RAM存储器: random access memory 随机存取存储器 --》可读可写 断电信息不丢失
既然BIOS程序是固化到只读存储器上面的那么BIOS的一些基本配置保存到哪里?
BIOS的配置固化到了主板上面的CMOS芯片上面, BIOS是一个程序会读取CMOS芯片里的参数,了解cpu的配置,时间的配置,启动顺序的配置等
CMOS芯片:CMOS芯片是一种低耗电存储器,其主要作用是用来存放BIOS程序中的设置信息以及系统时间日期。如果CMOS中数据损坏,计算机将无法正常工作
##############################################
boot : 引导、启动的意思
关于boot启动顺序:
第一引导顺序:Removable Devices 可移动设备 (U盘、移动硬盘等)
第二引导顺序:Hard Drive 硬盘
第三引导顺序:CD-ROM Drive 光驱 (安装系统)
第四引导顺序:Network boot from Intel 网络中安装服务器启动
##############################################
计算机在按下power键后,开始执行主板BIOS程序,进行完一系列检测和配置以后,
开始按BIOS设定的引导顺序引导系统,会从硬盘中引导系统,BIOS执行完自己的程序以后
如何将执行权交给硬盘?
MBR程序:master boot record 主引导记录,位于硬盘的0磁道,0柱面,1扇区,可以看成是硬盘的第一个扇区,MBR里面有一个grub2引导程序,负责启动linux系统
磁盘上面有很多磁道,每个磁道又会划分成63个扇区,每个扇区可以存储512个字节
MBR主引导记录的组成:
分区表 + grub2主引导程序 + 类型 总共512个字节
grub是linux系统的启动程序
grub2是grub的第2个版本
##############################################
2.2.6 加载/boot里面的光驱
/boot目录下面的内容:
grub2程序会舒适化硬件设备,建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统做好一切准备。
initramfs-4.18.0-147.el8.x86_64.img 文件:
给内核程序提供一个初始化的内存文件系统的镜像文件 --》临时的根文件系统的镜像文件-->提供程序和配置文件
init 初始化
ram 内存里的存储
fs 文件系统
vmlinuz-4.18.0-147.el8.x86_64 文件
内核程序文件。
##############################################
2.2.7 启动systemd进程
由于版本的不同,centos6里面启动的第一个进程是init,centos7里面是systemd进程
- [root@wangsh boot]# pstree -p
- systemd(1)─┬─NetworkManager(749)─┬─{NetworkManager}(757)
- │ └─{NetworkManager}(762)
- ├─VGAuthService(671)
- ├─auditd(646)───{auditd}(647)
- ├─chronyd(679)
- ├─crond(700)
- ├─dbus-daemon(676)───{dbus-daemon}(691)
- ├─login(714)───bash(1325)
- ├─lvmetad(505)
- ├─master(1227)─┬─pickup(4840)
- │ └─qmgr(1237)
- ├─nginx(2248)───nginx(2249)
- ├─polkitd(673)─┬─{polkitd}(692)
- │ ├─{polkitd}(695)
- │ ├─{polkitd}(696)
- │ ├─{polkitd}(698)
- │ ├─{polkitd}(699)
- │ └─{polkitd}(709)
- ├─rsyslogd(1063)─┬─{rsyslogd}(1066)
- │ └─{rsyslogd}(1067)
- ├─sshd(1059)───sshd(4254)───bash(4258)───pstree(4930)
- ├─systemd-journal(488)
- ├─systemd-logind(694)
- ├─systemd-udevd(521)
- ├─tuned(1060)─┬─{tuned}(1307)
- │ ├─{tuned}(1308)
- │ ├─{tuned}(1310)
- │ └─{tuned}(1312)
- └─vmtoolsd(672)─┬─{vmtoolsd}(710)
- └─{vmtoolsd}(717)
##############################################
运行级别:runlevel(是centos6的叫法,)
0 关机
1 单用户模式
2 多用户模式,不能使用nfs
3 完全多用户模式 --》字符界面模式 --》非常正常的模式, 默认最小化安装的模式
4 保留,没使用
5 图形界面
6 重启
init 0 关机
init 3 进入字符界面
init 6 重启
init 5 进入图形界面,但是需要安装了图形界面
查看当前运行级别
- [root@wangsh boot]# runlevel
- N 3
- [root@wangsh boot]#
N代表之前最开始进入的模式,如果是N表示没有的模式,没有进行模式切换
3 5 代表开机是先进入运行级别3,后来切换到运行级别5
查看/etc/inittab文件
- [root@wangsh boot]# vim /etc/inittab
-
- # inittab is no longer used when using systemd.
- #
- # ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON YOUR SYSTEM.
- #
- # Ctrl-Alt-Delete is handled by /usr/lib/systemd/system/ctrl-alt-del.target
- #
- # systemd uses 'targets' instead of runlevels. By default, there are two main targets:
- #
- # multi-user.target: analogous to runlevel 3
- # graphical.target: analogous to runlevel 5
- #
- # To view current default target, run:
- # systemctl get-default
- #
- # To set a default target, run:
- # systemctl set-default TARGET.target
可以看到这个文件里面说:
- multi-user.target: analogous to runlevel 3
- graphical.target: analogous to runlevel 5
multi-user.target类似于第3运行级别
graphical.target类似于第5运行级别
- # To view current default target, run:
- # systemctl get-default
- #
- # To set a default target, run:
- # systemctl set-default TARGET.target
- #
显示当前的默认运行级别使用这条命令
systemctl get-default 查看默认的运行级别
设置开机进入图形界面
set-default graphical.target
- [root@wangsh boot]# systemctl get-default
- multi-user.target
- [root@wangsh boot]# systemctl set-default graphical.target
##############################################
- [root@wangsh multi-user.target.wants]# pwd
- /etc/systemd/system/multi-user.target.wants
- [root@wangsh multi-user.target.wants]# ls
- auditd.service irqbalance.service remote-fs.target tuned.service
- chronyd.service kdump.service rhel-configure.service vmtoolsd.service
- crond.service NetworkManager.service rsyslog.service
- firewalld.service postfix.service sshd.service
- [root@wangsh multi-user.target.wants]# ll
- 总用量 0
- lrwxrwxrwx. 1 root root 38 11月 12 2021 auditd.service -> /usr/lib/systemd/system/auditd.service
- lrwxrwxrwx. 1 root root 39 11月 12 2021 chronyd.service -> /usr/lib/systemd/system/chronyd.service
- lrwxrwxrwx. 1 root root 37 11月 12 2021 crond.service -> /usr/lib/systemd/system/crond.service
- lrwxrwxrwx. 1 root root 41 7月 26 15:03 firewalld.service -> /usr/lib/systemd/system/firewalld.service
- lrwxrwxrwx. 1 root root 42 11月 12 2021 irqbalance.service -> /usr/lib/systemd/system/irqbalance.service
- lrwxrwxrwx. 1 root root 37 11月 12 2021 kdump.service -> /usr/lib/systemd/system/kdump.service
- lrwxrwxrwx. 1 root root 46 11月 12 2021 NetworkManager.service -> /usr/lib/systemd/system/NetworkManager.service
- lrwxrwxrwx. 1 root root 39 11月 12 2021 postfix.service -> /usr/lib/systemd/system/postfix.service
- lrwxrwxrwx. 1 root root 40 11月 12 2021 remote-fs.target -> /usr/lib/systemd/system/remote-fs.target
- lrwxrwxrwx. 1 root root 46 11月 12 2021 rhel-configure.service -> /usr/lib/systemd/system/rhel-configure.service
- lrwxrwxrwx. 1 root root 39 11月 12 2021 rsyslog.service -> /usr/lib/systemd/system/rsyslog.service
- lrwxrwxrwx. 1 root root 36 11月 12 2021 sshd.service -> /usr/lib/systemd/system/sshd.service
- lrwxrwxrwx. 1 root root 37 11月 12 2021 tuned.service -> /usr/lib/systemd/system/tuned.service
- lrwxrwxrwx. 1 root root 40 11月 12 2021 vmtoolsd.service -> /usr/lib/systemd/system/vmtoolsd.service
可以看到,这些文件其实都是链接文件,指向Linux中的要开机自启的服务。
我们使用systemctl disable firewalld这条命令其实就是将这个目录下面的链接文件去除
使用systemctl enable firewalld这条命令就是在这个目录添加firewalld服务的链接
- [root@wangsh multi-user.target.wants]# systemctl disable firewalld
- Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
- Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
- [root@wangsh multi-user.target.wants]# systemctl enable firewalld
- Created symlink from /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service to /usr/lib/systemd/system/firewalld.service.
- Created symlink from /etc/systemd/system/multi-user.target.wants/firewalld.service to /usr/lib/systemd/system/firewalld.service.
##############################################
rc.local文件:
如果想执行这个文件必须给他赋予可执行权限。
- [root@wangsh multi-user.target.wants]# cat /etc/rc.local
- #!/bin/bash
- # THIS FILE IS ADDED FOR COMPATIBILITY PURPOSES
- #
- # It is highly advisable to create own systemd services or udev rules
- # to run scripts during boot instead of using this file.
- #
- # In contrast to previous versions due to parallel execution during boot
- # this script will NOT be run after all other services.
- #
- # Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
- # that this script will be executed during boot.
-
- touch /var/lock/subsys/local
-
-
- [root@wangsh multi-user.target.wants]# ll -d /etc/rc.local
- lrwxrwxrwx. 1 root root 13 11月 12 2021 /etc/rc.local -> rc.d/rc.local
/etc/fstab
告诉linux正常启动过程中挂载哪个磁盘分区
- [root@wangsh multi-user.target.wants]# cat /etc/fstab
-
- #
- # /etc/fstab
- # Created by anaconda on Fri Nov 12 20:24:42 2021
- #
- # Accessible filesystems, by reference, are maintained under '/dev/disk'
- # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
- #
- /dev/mapper/centos-root / xfs defaults 0 0
- UUID=5f971381-8a7b-4d83-8113-628cfee0a009 /boot xfs defaults 0 0
- /dev/mapper/centos-swap swap swap defaults 0 0
##############################################
2.2.11 login登录
login登录查询启动,用户输入用户名和密码以后
Linux系统会自动进入/etc/passwd文件查找文件名
再根据用户名到/etc/shadow文件查找密码
##############################################
登录成功后会加载四个配置文件
/etc/profile 全局配置,对所有用户有效
/etc/bashrc 全局配置,对所有用户有效
~/.bash_profile 局部配置,只对登录的用户生效
~/.bashrc 局部配置,只对登录的用户生效
来看看.bash_profile的内容:
如果,~/.bashrc文件存在就执行这个文件
~/.bashrc文件有这样一行内容
如果/etc/bashrc文件存在就执行这个文件
##############################################
将程序做成一个服务,放到/etc/systemd/system/multi-user.target.wants目录下面。
这个目录下面放的都是开机自启的服务
在/etc/rc.local文件里面添加一条运行程序的命令,就会开机自启
在四个配置文件里面添加运行程序的命令,就会开机自启
还可以添加计划任务,让程序自动运行
在/etc/systemd/system/multi-user.target.wants目录下面查找有没有这个服务
- [root@wangsh multi-user.target.wants]# ls | grep firewalld
- firewalld.service
- [root@wangsh multi-user.target.wants]#