手把手系列(三)教你自制简单Linux系统

CentOS启动相关最重要的几个文件有:内核vmlinuz文件、虚拟文件系统initramfs文件、grub文件以

及init启动程序,围绕这几个文件,我们来制作一个能够简单启动的自制Linux系统

实验思路:

CentOS6的启动流程如下

1.加载BIOS的硬件信息,进行POST加电自检

2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息

3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱动所有的硬件设备

4.核心执行init程序,并获取默认的运行信息

5.init程序执行/etc/rc.d/rc.sysinit文件

6.启动核心的外挂模块

7.init执行运行的各个批处理文件(scripts)

8.init执行/etc/rc.d/rc.local

9.执行/bin/login程序,等待用户登录

10.登录之后开始以Shell控制主机

其中与启动相关最重要的几个文件有:内核vmlinuz文件、虚拟文件系统initramfs文件、grub文件以

及init启动程序,接下来就围绕这几个重要文件,来制作一个能够简单启动的自制Linux系统

 

准备环境:

CentOS6虚拟服务器1台,准备一个硬盘或者U盘,本实验我们以一块20G的虚拟硬盘为例制作一个简单的

Linux系统

u=1560722224,2576059153&fm=27&gp=0

 

具体步骤:

第一步:针对新增加的20G硬盘创建两个分区dev/sdb1,dev/sdb2

fdisk /dev/sdb

fdisk

第二步:创建文件系统,将/dev/sdb1,/dev/sdb2两个分区文件系统设置为ext4格式

mkfs.ext4  /dev/sdb1

mkfs.ext4  /dev/sdb2

做文件系统

第三步:挂载/boot目录

mkdir /mnt/boot                                此处挂载子目录必须为boot

mount /dev/sdb1 /mnt/boot

挂载boot

第四步:安装gurb

grub-install –root-director=/mnt /dev/sdb

hexdump -C /dev/sdb -n 512 -v                 查看一阶段是否创建成功,446字节已生成

ls /mnt/boot                                查看二阶段是否创建成功,grub目录已生成

查看

第五步:拷贝内核vmlinuz文件及虚拟文件系统initramfs文件

cp /boot/vmlinuz-VERSION /mnt/boot/vmlinuz

cp /boot/initramfs-VERSION.img /mnt/boot/initramfs.img

内核文件

第六步:设置grub.conf文件

vim /grub.conf

default=0

timeout=5

title linux

kernel /vmlinuz-VERSION  root=/dev/sda2 init=/bin/bash

initrd /initramfs.img

vim

第七步:挂载根目录

mkdir /mnt/rootfs

mount /dev/sdb2 /mnt/rootfs

挂载根目录

第八步:复制相关命令和库文件

如:ifconfig,insmod,ping,mount,ls cat,df,lsblk,blkid等

 

第九步:准备根目录下必要目录

mkdir /mnt/rootfs/{dev,etc,proco,sys,usr,var,lib,mnt.home,root,tmp,lib64} -v

sync;sync;sync; 确保写入硬盘

必要目录

第十步:安装必要的模块,如网络模块等

网络模块

第十一步:关机此服务器,并将20G硬盘安装到一台无硬盘启动的虚拟机服务器上

C4]~MJXP350W{7KIN`G88G0

我们看到系统已经可以正常启动了,一台可以快速、简单完成启动的Linux系统就制作完成了

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/98532

(3)
上一篇 2018-05-14 18:27
下一篇 2018-05-14 20:33

相关推荐

  • 编译安装软件

    编译安装httpd软件 1先配置yum源 准备工作:把所有yum源改成本地光盘 [root@centos7 etc]#find *yum*(查找yum配置目录) 1.[root@centos6 ~]#df .[root@centos6 ~]#cd /misc/cd/ (神奇文件自动挂载)光盘 [root@centos7 yum.repos.d]#ls(说明还…

    Linux笔记 2018-04-22
  • 加密和安全

    常见的加密算法和安全协议 一、对称加密:加密和解密使用同一个密钥,依赖于算法和密钥,其安全性依赖于密钥而非算法 常见的算法:DES ​ 特性: ​ 加密、解密使用同一个密钥 ​ 将明文分隔成固定的大小块逐个进行加密 ​ 缺点: ​ 密钥过多、密钥分发 二、非对称加密:采用的是公钥加密方法,密钥是成对出现的,公钥是从私钥中提取出来的 ​ 公钥:公开给所有人;p…

    Linux笔记 2018-05-10
  • 文本三剑客之一 “sed” 命令的一些用法。

    分为基本用法跟高级用法。

    Linux笔记 2018-04-22
  • TCP/IP协议栈 和IP地址规划

    TCP/IP IP地址的规划

    2018-05-15
  • liniux课程第一周总结

    第一天课程内容 MBR分区类型:主分区:1-4,一块硬盘最多4个主分区,不可以分小区,可以用来启动操作系统(系统分区),直接建文件系统,存放数据扩展分区:一块硬盘最多一个扩展分区,可以没有,加主分区最多4个,不能创建文件系统,可以再划分更小的分区(即逻辑分区)逻辑驱动器(分区):可以创建文件系统,存放数据 系统分区:启动操作系统的分区启动分区:安装操作系统的…

    Linux笔记 2018-04-01
  • .

    .

    Linux笔记 2018-05-17