Linux system is a widely used open source operating system with powerful functions and flexible configuration. However, have you ever thought about how the Linux system gradually starts up from darkness when you press the power button? The boot process of Linux system startup is a complex and delicate process, which involves multiple levels and components such as hardware, firmware, boot loader, kernel and user space. This article will analyze in detail the boot process of Linux system startup, including BIOS, MBR, GRUB, initrd, init, etc.
The following takes CentOS5.5 version as an example to introduce the boot process of LINUX. The specific process is as follows:

The following is a detailed introduction to each step:
1) The first step is firmware self-test, which mainly performs CMOS/BIOS POST power-on self-test on the hardware to check whether the hardware is normal at the physical level. For example, check whether the hard disk is plugged in properly, etc.
2) The second step is to read the BootLoader of the MBR in the hard disk and the self-starting program. The commonly used self-starting program under Linux is GRUB. The main function of this step is to load the kernel. The kernel is stored in the /boot directory
3) The third step is the process of loading the kernel Kernel,
The main functions are: 1. Drive hardware. Kernel contains a large number of drivers. 2. Start the init process.
4) The init process mainly reads the /etc/inittab file and executes the default run level to continue booting. It should be noted that the PID of init is always 1, which is the parent process of all processes, while the background process of init process is 0, which is the kernel scheduler.
5)/etc/inittab defines initialization operations.
The main format of the command is: id: runlevels: action: process
Among them, as shown in the red box in the above picture
1. There are 7 run-levels, 0-6 are as follows:
0 —— halt shutdown
1 ——Single user mode Single user mode
2 - Multiuser, withoutNFS multi-user mode without network (text mode)
3——Full multiuser mode Full-featured multi-user mode (text mode)
4——unused reserved
5 ——X11 graphical multi-user mode
6——reboot
You can switch according to these 7 running levels
The commands are: view the current running level #runlevel, switch the running level #init[0 |1 |2 |3 |4 |5 |6]
2. There are also several important values in acion:
1 initdefault: Specify the default startup run level of the system, as marked in the above figure, usually used for repair. For example, if we want to enter single-user mode, we can set it to 1. The default cannot be set to 0 or 6. Otherwise it cannot be started.
2sysinit: The system starts executing the command specified in the process
It can be seen from the content of the inittab file that there is no run level set, which means that no matter which run level it is, /etc/rc.d/rc.sysinit will be executed
6) initdefault, as mentioned in the fifth step, mainly reads the information in /etc/inittab to determine what the default running level is.
7)/etc/rc.d/rc.sysinit
Run to line 21 in the inittab file to start the script. Complete the startup of the system service program, such as setting system environment variables, setting the system clock, loading fonts, checking the loaded file system, generating system startup information log files, etc. Because it is a basic service, its run-level is set to empty: that is, any level, and the action is set to sysinit. That is, the script must be started at any run level to complete the startup of the basic service
8) After the basic service is started, the script /etc/rc.d/rc will be executed
After loading the basic service, you need to start the corresponding directory according to different running levels. Its working principle is to first determine the default running level of the system, which is what is in step 6, and then execute the corresponding rcN. The service startup script in the d directory is as shown
9) Execute the service startup script in the /etc/rc.d/rcN.d directory
Look at the contents of this directory:
where S represents the script to be started and K represents the script to be closed
The numbers indicate the startup sequence, with smaller values given priority. Mainly for the management of some services
In this step, you need to explain the directory /etc/rc.d/init.d. The scripts placed in this directory are real scripts, while the scripts placed in rcN.d are soft links in the init.d directory. In other words, all files in rcN.d will eventually need to find the real script in init.d
Take a look at the specific details:

After executing this step, the interface will prompt you to enter the user name and password, which means that the system has started. The process of entering the user name and password will be discussed later. This time the boot process is over
The last thing to note is that the idea of the LINUX boot process is roughly the same, but the details are different due to version issues, in the name or location of the configuration file. This time I used the CentOS version, and the Ubuntu version There is no inittab file and grup.conf file, so if you are interested, you can follow this idea to explore.
PS: About GRUB
GNU GRUB ("GRUB" for short) is a bootloader from the GNU project. GRUB is an implementation of the multi-boot specification, which allows users to have multiple operating systems in the computer at the same time and select the operating system they want to run when the computer starts. GRUB can be used to select different kernels on an operating system partition and can also be used to pass boot parameters to these kernels.
The predecessor of GNU GRUB is Grand Unified Bootloader. It is mainly used in Unix-like systems; like most Linux distributions, GNU systems also use GNU GRUB as its launcher. Starting from version 10 1/06, Solaris also uses GNU GRUB as the launcher on x86 systems.
GRUB is dynamically configurable; it loads configuration information at startup and allows modification at startup, such as selecting a different kernel and initrd. For this purpose, GRUB provides a simple Bash-like command line interface, which allows users to write new startup sequences.
GRUB is very lightweight. It supports a variety of executable formats; in addition to being applicable to operating systems that support multi-boot, it also supports operating systems such as Windows and OS/2 that do not support multi-boot through the chain boot function. GRUB supports all Unix file systems, as well as FAT and NTFS file systems for Windows, and also supports LBA mode. GRUB allows users to view the contents of files in the file systems it supports.
GRUB has a variety of user interfaces. Most Linux distributions take advantage of GRUB's support for graphical interfaces to provide customized boot menus with background patterns, and sometimes also support mouse. By setting the GRUB text interface, remote terminal startup can be achieved through the serial port.
GRUB can download operating system images from the network, so it can support diskless systems. GRUB supports decompressing the image of the operating system before booting it.
Unlike other launchers, GRUB can interact directly with users through the GRUB prompt. Before loading the operating system, type the c key in the GRUB text mode screen to enter the GRUB command line. On systems without an operating system or with an operating system but no "menu.lst" file, you can also enter the GRUB prompt. The GRUB prompt allows users to manually boot any operating system through bash-like commands. Record the appropriate commands in the "menu.lst" file to automatically start an operating system.
GRUB has a rich set of terminal commands. Using these commands from the command line, users can view the details of hard disk partitions, modify partition settings, temporarily remap the disk order, boot from any user-defined configuration file, and view what GRUB supports. Configuration of other launchers on the file system. Therefore, it is possible to boot an operating system from an external device without knowing what is installed on a computer.
GRUB uses a scrolling screen to select the operating system you want to start. By adding relevant information to the "menu.lst" file, GRUB can control 150 or more startup options, which can be selected with the arrow keys at startup.
With chain startup, one starter can start another starter. GRUB can be started from DOS, Windows, Linux, BSD and Solaris systems with 2 to 3 lines of commands.
Although GRUB is compiled and packaged for Unix-like systems, there is also GRUB for DOS and Windows. GRUB can also be installed as an isolated system without any operating system. Using GRUB requires 1 file when booting from a CD, and 2 files when booting from a floppy disk, hard disk, and USB device. These files can be found on any Linux CD that supports GRUB, and users can easily find them.
This article analyzes in detail the boot process of Linux system startup, including BIOS, MBR, GRUB, initrd, init, etc. By understanding and mastering this knowledge, we can better understand the inner workings of the Linux system, and thus better use and optimize the Linux system. Of course, there are many details and changes in the boot process of Linux system startup, which require us to continue to learn and explore.
The above is the detailed content of Analyze the boot process of Linux system startup. For more information, please follow other related articles on the PHP Chinese website!

linux设备节点是应用程序和设备驱动程序沟通的一个桥梁;设备节点被创建在“/dev”,是连接内核与用户层的枢纽,相当于硬盘的inode一样的东西,记录了硬件设备的位置和信息。设备节点使用户可以与内核进行硬件的沟通,读写设备以及其他的操作。

区别:1、open是UNIX系统调用函数,而fopen是ANSIC标准中的C语言库函数;2、open的移植性没fopen好;3、fopen只能操纵普通正规文件,而open可以操作普通文件、网络套接字等;4、open无缓冲,fopen有缓冲。

端口映射又称端口转发,是指将外部主机的IP地址的端口映射到Intranet中的一台计算机,当用户访问外网IP的这个端口时,服务器自动将请求映射到对应局域网内部的机器上;可以通过使用动态或固定的公共网络IP路由ADSL宽带路由器来实现。

在linux中,eof是自定义终止符,是“END Of File”的缩写;因为是自定义的终止符,所以eof就不是固定的,可以随意的设置别名,linux中按“ctrl+d”就代表eof,eof一般会配合cat命令用于多行文本输出,指文件末尾。

在linux中,交叉编译是指在一个平台上生成另一个平台上的可执行代码,即编译源代码的平台和执行源代码编译后程序的平台是两个不同的平台。使用交叉编译的原因:1、目标系统没有能力在其上进行本地编译;2、有能力进行源代码编译的平台与目标平台不同。

在linux中,可以利用“rpm -qa pcre”命令判断pcre是否安装;rpm命令专门用于管理各项套件,使用该命令后,若结果中出现pcre的版本信息,则表示pcre已经安装,若没有出现版本信息,则表示没有安装pcre。

在linux中,rpc是远程过程调用的意思,是Reomote Procedure Call的缩写,特指一种隐藏了过程调用时实际通信细节的IPC方法;linux中通过RPC可以充分利用非共享内存的多处理器环境,提高系统资源的利用率。

linux查询mac地址的方法:1、打开系统,在桌面中点击鼠标右键,选择“打开终端”;2、在终端中,执行“ifconfig”命令,查看输出结果,在输出信息第四行中紧跟“ether”单词后的字符串就是mac地址。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Atom editor mac version download
The most popular open source editor

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
