首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux内核启动流程图

Linux内核启动流程主要包括以下阶段:

一、引导阶段

  1. BIOS/UEFI启动
    • 计算机开机后,BIOS(基本输入输出系统)或UEFI(统一可扩展固件接口)进行硬件自检。
    • 检查无误后,BIOS/UEFI根据设置的启动顺序查找启动设备(如硬盘、U盘等)。
  • 加载引导程序
    • 引导程序(如GRUB)被加载到内存中并执行。
    • GRUB负责加载Linux内核映像和初始化RAM磁盘(initrd)。

二、内核初始化阶段

  1. 内核解压与加载
    • 如果内核是压缩的,GRUB会先将其解压。
    • 内核映像被加载到内存中,并开始执行初始化代码。
  • 设置硬件环境
    • 内核探测并配置硬件设备,如CPU、内存、硬盘等。
    • 初始化中断控制器、定时器等关键硬件组件。
  • 挂载根文件系统
    • 使用initrd中的工具挂载实际的根文件系统。
    • initrd随后被卸载,内核将控制权交给根文件系统中的init进程。

三、系统初始化阶段

  1. 启动init进程
    • init进程是系统启动的第一个用户空间进程,PID为1。
    • 它负责启动系统服务、守护进程和shell。
  • 执行系统初始化脚本
    • 根据不同的Linux发行版,init进程会执行相应的初始化脚本(如SysV init、systemd等)。
    • 这些脚本负责配置网络、启动服务等。
  • 用户登录
    • 系统初始化完成后,init进程会启动登录管理器(如GDM、LightDM等)。
    • 用户通过登录界面输入凭证,进入系统。

四、应用启动阶段

  1. 启动用户应用程序
    • 用户登录后,可以手动或自动启动各种应用程序。

优势

  • 模块化设计:Linux内核采用模块化设计,便于扩展和维护。
  • 稳定性:经过长时间的发展和广泛测试,Linux内核具有很高的稳定性。
  • 安全性:Linux内核具有强大的安全机制,如SELinux、AppArmor等。

应用场景

  • 服务器:Linux内核广泛应用于服务器领域,如Web服务器、数据库服务器等。
  • 嵌入式系统:由于其灵活性和可定制性,Linux内核也常用于嵌入式系统。
  • 移动设备:Android操作系统基于Linux内核,应用于智能手机和平板电脑。

注意事项

  • 内核版本选择:不同的内核版本可能对硬件支持和软件兼容性有影响,需根据实际需求选择合适的内核版本。
  • 内核模块管理:合理管理内核模块,避免不必要的模块加载,以提高系统性能和安全性。

解决常见问题

  • 内核启动失败:检查引导程序配置、内核映像完整性、根文件系统挂载等。
  • 硬件兼容性问题:更新内核版本或安装相应的内核模块。

由于绘制流程图较为复杂,这里无法直接提供流程图,但你可以参考上述步骤在流程图绘制工具中自行绘制。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

linux内核启动流程(文章最后流程图)

原文:linux内核启动流程 本文以Linux3.14版本源码为例分析其启动流程。各版本启动代码略有不同,但核心流程与思想万变不离其宗。 内核映像被加载到内存并获得控制权之后,内核启动流程开始。...得到内核入口函数为 stext(linux/arch/arm/kernel/head.S) 内核引导阶段 ENTRY(stext) 。 。 。...部分书籍介绍的内核启动流程基于经典的2.6版本,kernel_init函数还会调用init_post函数专门负责_init进程的启动,现版本已经被整合到了一起。...当内核被引导并进行初始化后,内核启动了自己的第一个用户空间应用程序_init,这是调用的第一个使用标准C库编译的程序,其进程编号时钟为1....以下为内核启动流程图: 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/163595.html原文链接:https://javaforall.cn

1.7K40
  • Linux系统修改默认内核启动顺序

    grub2-set-default "CentOS Linux (3.10.0-123.9.3.el7.x86_64) 7 (Core)" 3、执行如下命令,确认配置成功。...2、在grub.conf文件中决定开机使用哪个内核版本做启动的参数是default,默认值为0,代表从最新的内核启动。代表启动的内核版本从上往下依次是0、1、2等。...3、如果要选择从旧版内核,即系统最开始的内核启动,则把default值改为1 ,然后重启服务器从新的内核进行引导。...三、centos8修改内核启动顺序 1、查看默认内核 grubby --default-kernel 2、 查看所有内核 grubby --info=ALL 3、修改默认启动内核 grubby --set-default...=0 ##修改为 GRUB_DEFAULT="Advanced options for Ubuntu>Ubuntu, with Linux 4.4.0-31-generic" 3、更新修改后的grub

    9.3K20

    TinyVision 使用 SyterKit 启动 Linux 6.7 主线内核

    TinyVision 使用 SyterKit 启动 Linux 6.7 主线内核 SyterKit SyterKit 是一个纯裸机框架,用于 TinyVision 或者其他 v851se/v851s/v851s3...同时 SyterKit 也具有启动引导的功能,可以替代 U-Boot 实现快速启动 获取 SyterKit 源码 SyterKit 源码位于GitHub,可以前往下载。...进入 syter_boot 文件夹,可以看到这些文件 由于 TinyVision 是 TF 卡启动,所以我们需要用到 syter_boot_bin_card.bin 移植 Linux 6.7 主线 有了启动引导.../WorkSpace/aa/linux-6.7-rc5/arch/arm/boot/dts/allwinner/Makefile sun8i-v851se-tinyvision.dtb 生成刷机镜像 编译内核后.../genimage.sh -c genimage.cfg 打包完成,可以找到 sdcard.img 使用软件烧录固件到TF卡上 测试 插卡,上电,成功启动系统 可以看到 Linux 版本是 6.7.0

    8610

    linux内核启动流程分析 - efi_main

    上一篇文章 linux内核启动流程分析 - efi_stub_entry 中,为了叙述方便,我们只是粗略的讲了下efi_main函数,这里我们再具体看下。 ?...有关boot_params的创建及其hdr的初始化,我们在 linux内核启动流程分析 - efi_pe_entry 中有讲到,这里就不再赘述。 继续看该函数的其余部分。 ?...而710行中的image_offset是kernel在内存的起始地址到compressed部分起始地址(startup_32的地址)的偏移量,这个在 linux内核启动流程分析 - efi_pe_entry...linux内核构建结束后,最终生成的文件是 arch/x86/boot/bzImage,这其实是个压缩过的内核,在kernel启动过程中,还要在内存中对内核进行解压,进而得到真正的内核。...综上可知,712行中的buffer_end表示的是kernel在启动过程中,需要使用的内存的结束地址。 714到717行是一些条件判断,在这些条件下,需要拷贝内存中的内核到合适的位置上。

    3.7K30

    Linux启动时间优化-内核和用户空间启动优化实践

    启动时间的优化,分为两大部分,分别是内核部分和用户空间两大部分。...从内核timestamp 0.000000作为内核启动起点,到free_initmem()输出"Freeing init memory"作为内核启动的终点。...内核启动优化 在内核源码中自带了一个工具(scripts/bootgraph.pl)用于分析启动时间,这个工具生成output.svg。...1.1.3 对bootgraph.py的改进 1.1.3.1 划分内核启动的起点终点 界定内核启动的起点很容易,从时间0开始。...Linux的启动从进入内核那一刻开始,到用户空间达到可用状态。 这个可用状态定义可能不一致,有的是进入shell,有的是弹出登陆框。但只要有一个固定的终点,就有了优化目标。

    92930

    Linux启动引导程序(GRUB)加载内核的过程

    我们知道启动引导程序(Boot Loader,也就是 GRUB)会在启动过程中加载内核,之后内核才能取代 BIOS 接管启动过程。如果没有启动引导程,那么内核是不能被加载的。...本节,我们就来看看启动引导程序加载内核的过程,当然 initramfs 这个虚拟文件系统也是要靠启动引导程序调用的。...GRUB加载内核的过程GRUB 的作用有以下几个:加载操作系统的内核;拥有一个可以让用户选择的的菜单,来选择到底启动哪个系统;可以调用其他的启动引导程序,来实现多系统引导。...那么 Linux 的解决办法是把 GRUB 的程序分成了三个阶段来执行。...接下来内核就可以接管启动过程,继续自检与加载硬件模块了。

    54720

    linux内核启动流程分析 - efistub的入口函数

    最近打算写一个系列文章,主要讲linux内核的启动流程。 网上类似标题的文章很多,但大都是从start_kernel讲起,我觉得这是远远不够的。...linux内核的启动方式有非常多种,大方向来看分为bios和uefi,在此基础上又有各种各样的boot loader,比如我们常见的grub,它们会根据配置信息,加载linux内核到内存,并通过一定的协议来启动...它的实现原理是,按照 uefi 指定的 pecoff 格式,将内核伪装成一个 uefi application,这样在支持 uefi 的各种硬件上,就可以按照 uefi 协议,直接启动linux内核了。...这样,当linux内核以 uefi application 的形式,被 uefi 直接启动时,被执行的第一行代码就是这个方法。...或者说,在 uefi 平台上,以 efi stub形式启动内核时,开机后内核执行的第一个方法就是该方法。 以这里为起点,我们就可以开始探索linux内核的完整启动流程了。

    3.6K30

    Linux启动流程 梳理| 思维导图 | 流程图 | 值得收藏

    Linux启动流程总的来说可以分成三个阶段 Linux启动流程图 第一步:上电 Ø在 x86 系统中,将 1M 空间最上面的 0xF0000 到 0xFFFFF 这 64K 映射给 ROM。...第三步:Linux启动 Linux启动-引导 Ø我们可以通过BIOS界面选择硬盘启动项进入OS,那BIOS是怎么发现这个硬盘里有OS?...GRUB是多启动规范的实现,它允许用户可以在计算机内同时拥有多个操作系统,并在计算机启动时选择希望运行的操作系统。GRUB可用于选择操作系统分区上的不同内核,也可用于向这些内核传递启动参数。...这里需要注意,它不是 Linux 的内核,而是 grub 的内核。...Linux启动-init介绍 Ø前面0/1进程都属于内核线程,ps pid=1的是init进程 Ø if (ramdisk_execute_command) { Øret = run_init_process

    26110

    ARM Linux 启动时的自解压过程 | Linux 内核

    最近业余时间都在学习 Linux 内核和英语,或者是陪家人玩耍,没有投入太多的时间在文章。 今天起得比较早,就给大家翻译一篇 linus 的文章吧,大家可以感受一下大神的写作能力。...OK,Let's go. ---- ARM Linux 一般都使用压缩的内核,例如 zImage。 这样做有两个主要原因: 1、节省存放内核的闪存或其他存储介质的空间。...例如从 NAND Flash 加载内核,就是一种很典型的情况。 本文将对 ARM Linux 的自解压过程进行一个简单介绍。...2002 年,Russell King 就在 Booting ARM Linux 文档中定义了 Booloader 引导 Linux 内核的 ABI。...另外还需要额外的空间,是因为当内核最终启动时,它将从该地址中减去 0x4000(或 LPAE 的 0x5000),并将初始内核页表 (initial kernel page table) 存储在那里。

    2.9K10

    【Linux】《how linux work》第五章 Linux内核的启动过程

    How the Linux Kernel Boots(第5章 Linux内核的启动过程) You now know the physical and logical structure of a Linux...你现在已经了解了Linux系统的物理和逻辑结构,知道了内核是什么,以及如何处理进程。 本章将教你内核是如何启动的。换句话说,你将学习内核如何将自己加载到内存中,直到第一个用户进程开始运行的过程。...在运行Linux内核时,引导加载程序会传递一组基于文本的内核参数,告诉内核它应该如何启动。 这些参数指定了许多不同类型的行为,例如内核应该产生多少诊断输出以及设备驱动程序特定的选项。...当遇到无法理解的参数时,Linux内核会保存该参数。内核在执行用户空间启动时会将该参数传递给init。例如,如果您添加了-s到内核参数中,内核会将-s传递给init程序,表示应该以单用户模式启动。...GRUB 执行启动命令,加载并执行配置的 linux 命令指定的内核。

    45410

    深入理解 Linux 启动过程 | QEMU 启动 linux 内核和自制根文件系统

    跟我一起来到故事开始的地方,深入 Linux 系统的启动流程,自己编译内核并制作根文件系统,并使用 QEMU 模拟启动。 前置知识# 昨天看到阮老师两篇文章 《计算机是如何启动的?》...和 《Linux 的启动流程》,对计算机的启动流程有了更加深入的理解,正好最近在做国产申威处理器的虚拟化支持性调研,称此机会深入了解一下 Linux 系统的启动流程,并使用 QEMU 模拟这一流程。...说明:本文介绍的方法同样可用于内核调试,但侧重于介绍 使用 QEMU 模拟 Linux 的启动流程 。...By 阮一峰 BusyBox By Wikipedia 第一步,用qemu启动linux内核,从跑个Helloworld开始 在qemu上运行BusyBox 编译内核出现:cc1: error: code...Linux内核 QEMU + Busybox 模拟 Linux 内核环境 Qemu 模拟环境 By CTF Wiki Linux 内核编译步骤及配置详解 注:本作品采用 知识共享署名-非商业性使用-相同方式共享

    4.8K30
    领券