实战自制Linux操作系统

实战自制Linux操作系统



自制linux系统

步骤概述:

1、新建一个硬盘
2、在该新硬盘上新建两个分区,一个当boot分区,一个当/分区
3、格式化并且挂载两个分区
4、安装grub至目标磁盘
5、为grub提供配置文件
6、复制内核文件和initrd文件
7、创建目标主机根文件系统
8、移植bash命令和其库文件到根文件系统
9、装载模块,实现网络功能
10、启动测试

具体操作步骤如下:

  1)为CentOS 6系统添加一块新的硬盘,然后启动,演示如下:

wKioL1fanDvzxq6sABaUN8GC7PE230.gif

 2)查看新添加的硬盘,并为添加好的磁盘分区,创建文件系统;

[root@CentOS6 ~]# fdisk -l /dev/sd[a-z]

Disk /dev/sda: 85.9 GB, 85899345920 bytes
255 heads, 63 sectors/track, 10443 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x0007eba7

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *           1          26      204800   83  Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2              26        7859    62914560   8e  Linux LVM
/dev/sda3            7860        9165    10490445   83  Linux
/dev/sda4            9166       10443    10265535    5  Extended
/dev/sda5            9166        9819     5253223+  83  Linux

Disk /dev/sdb: 21.5 GB, 21474836480 bytes   #可以看到新添加的硬盘 sdb
255 heads, 63 sectors/track, 2610 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000

    分三个主分区,分别作为为根分区,swap分区和boot分区,并创建对应的文件系统,操作如下:

[root@CentOS6 ~]# fdisk /dev/sdb #创建分区,
#创建文件系统如下命令:
[root@CentOS6 ~]# mkfs.ext4 /dev/sdb1
[root@CentOS6 ~]# mkswap /dev/sdb2
[root@CentOS6 ~]# mkfs.ext4 /dev/sdb3
#查看创建好的分区
[root@CentOS6 ~]# blkid 
/dev/sdb1: UUID="f4921d76-f089-4cb6-8f47-aff34711cb7a" TYPE="ext4" 
/dev/sdb2: UUID="3eaa649e-a5c0-4f9c-8887-453368419238" TYPE="swap" 
/dev/sdb3: UUID="286c857d-8f52-465f-9ed6-8eeaa3363743" TYPE="ext4"

 3)创建一个boot目录,并把boot分区(sdb1)挂载上;

[root@CentOS6 ~]# mkdir /mnt/boot
[root@CentOS6 ~]# mount /dev/sdb1 /mnt/boot
[root@CentOS6 ~]# df
Filesystem           1K-blocks    Used Available Use% Mounted on
/dev/mapper/vg0-root  20511356 1112808  18349972   6% /
tmpfs                   502068       0    502068   0% /dev/shm
/dev/sda1               194241   34199    149802  19% /boot
/dev/mapper/vg0-usr   10190136 2473060   7192788  26% /usr
/dev/mapper/vg0-var   20511356  489148  18973632   3% /var
/dev/sda5              5039592   10352   4766580   1% /home
/dev/sdb1               104769    1550     97598   2% /mnt/boot  # 挂载的设备sdb1

 4)创建grub,并查看;

[root@CentOS6 ~]# ls /mnt/boot/
lost+found
[root@CentOS6 ~]# grub-install --root-directory=/mnt /dev/sdb #创建grub
Probing devices to guess BIOS drives. This may take a long time.
Installation finished. No error reported.
This is the contents of the device map /mnt/boot/grub/device.map.
Check if this is correct or not. If any of the lines is incorrect,
fix it and re-run the script `grub-install'.

(fd0)	/dev/fd0
(hd0)	/dev/sda
(hd1)	/dev/sdb
[root@CentOS6 ~]#  ls /mnt/boot/
grub  lost+found
[root@CentOS6 ~]#  ls /mnt/boot/grub/
device.map     fat_stage1_5  iso9660_stage1_5  minix_stage1_5     stage1  ufs2_stage1_5    xfs_stage1_5
e2fs_stage1_5  ffs_stage1_5  jfs_stage1_5      reiserfs_stage1_5  stage2  vstafs_stage1_5

    5)要想成为一个真正的系统,还需要内核文件,initrd以及grub/grub.conf这些文件;

[root@CentOS6 ~]# cp /boot/vmlinuz-2.6.32-642.el6.x86_64 /mnt/boot/vmlinuz
[root@CentOS6 ~]# cp /boot/initramfs-2.6.32-642.el6.x86_64.img /mnt/boot/initramfs.img
[root@CentOS6 ~]# vim /mnt/boot/grub/grub.conf  #手动编写配置文件
 default=0
 timeout=5
 title CentOS (Express)
         root (hd0,0) # 在当前下为第二块磁盘应为(hd1,0),但是如果自其它设备上使用为(hd0,0)
     kernel /vmlinuz ro root=/dev/sda3  #加载的根目录所在的分区,因为在其他设备上为第一块磁盘所以为 /dev/sda3
     initrd /initramfs.img #内核匹配的ramfs文件

 6)要把/dev/sda3当做根文件系统,就需要挂载,并创建根文件系统下想对应的子目录:

[root@CentOS6 ~]# mkdir /mnt/sysroot
[root@CentOS6 ~]# mount /dev/sdb3 /mnt/sysroot/
[root@CentOS6 ~]# cd /mnt/sysroot/
[root@CentOS6 sysroot]# ls
lost+found
[root@CentOS6 sysroot]# mkdir -pv etc bin sbin lib lib64 dev proc sys mnt var usr home root tmp media
mkdir: created directory `etc'
mkdir: created directory `bin'
mkdir: created directory `sbin'
mkdir: created directory `lib'
mkdir: created directory `lib64'
mkdir: created directory `dev'
mkdir: created directory `proc'
mkdir: created directory `sys'
mkdir: created directory `mnt'
mkdir: created directory `var'
mkdir: created directory `usr'
mkdir: created directory `home'
mkdir: created directory `root'
mkdir: created directory `tmp'
mkdir: created directory `media'
[root@CentOS6 sysroot]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  proc  root  sbin  sys  tmp  usr  var

 7)根文件系统的目录有了,但是要想运行还需要程序,还需要bash,以及基于动态编译的共享库文件

[root@CentOS6 sysroot]# cp /bin/bash /mnt/sysroot/bin  #复制bash
[root@CentOS6 sysroot]# ldd /bin/bash # 查看库文件
	linux-vdso.so.1 =>  (0x00007ffd127d9000)
	libtinfo.so.5 => /lib64/libtinfo.so.5 (0x0000003278e00000)
	libdl.so.2 => /lib64/libdl.so.2 (0x000000326f200000)
	libc.so.6 => /lib64/libc.so.6 (0x000000326f600000)
	/lib64/ld-linux-x86-64.so.2 (0x000000326ee00000)
 # 复制共享库中的文件到创建的根目录中的lib64下
[root@CentOS6 sysroot]# cp /lib64/libtinfo.so.5 /mnt/sysroot/lib64
[root@CentOS6 sysroot]# cp /lib64/libdl.so.2 /mnt/sysroot/lib64
[root@CentOS6 sysroot]# cp /lib64/libc.so.6 /mnt/sysroot/lib64
[root@CentOS6 sysroot]# cp /lib64/ld-linux-x86-64.so.2 /mnt/sysroot/lib64

 8)如上,基本的操作已经完成,使用 chroot 切换根,进行测试,如下:

[root@CentOS6 sysroot]# chroot /mnt/sysroot/    # 切换根
bash-4.1# 
bash-4.1# 
bash-4.1# ls  # 因为没有复制命令,所以只能使用内建命令,如果需要使用外部命令,就把命令以及以依赖的库复制过去就可以了。
bash: ls: command not found
bash-4.1# pwd                
/
bash-4.1# exit
exit

 9)最后,我们在编辑一下配置文件/mnt/boot/grub/grub.conf

[root@CentOS6 ~]# vim /mnt/boot/grub/grub.conf
default=0
timeout=5
title CentOS (Express)
     root (hd0,0)   
     kernel /vmlinuz ro root=/dev/sda3 init=/bin/bash  # 表示要求限定运行的的是/bin/bash 而不是 /sbin/init 这样就直接把bash当做用户空间的第一个进程来使用了
     initrd /initramfs.img

 10)最后同步一下

[root@CentOS6 ~]# sync

 11)我们新建一个虚拟机,把硬盘改为新创建好的磁盘,测试系统能否启动?

wKiom1fbXj3BezK9AACC8PyI_Jc126.png

   启动此虚拟机,如下图:按e键可以看到我们创建的系统文件,选定内核,按b键启动

wKioL1fbXraQpDp-ABToss86vNM266.gif

   选定内核,按b键启动,发现系统报错,什么原因呢?可能是没有添加selinux策略

wKiom1fbYTHSmxD2AAAwuZm83uM581.png   选定内核,按e键,进入编辑模式,添加selinux=0 ,重新启动,发现可以正常启动

wKiom1fbYuTC4EwrAAAtjQb-BJQ839.png


到此,一个迷你版的Linux诞生了,可以装在自己移动U盘等设备上面,这里不做过多解释

原创文章,作者:zhumengxiaotao,如若转载,请注明出处:http://www.178linux.com/47762

(0)
zhumengxiaotaozhumengxiaotao
上一篇 2016-09-19 14:45
下一篇 2016-09-19 14:55

相关推荐

  • 脚本的进阶与一些基本脚本

    1,脚本中用于表示数字大小写和符号为: -gt(大于)-lt(小于)-ne(不等于)-eq(等于) 格式为 [[空格 ”符号”空格]] 2,测试文件类型的选项 -f(是否为普通文件)-l(是否为链接文件)-d(是否为目录)-e(单独测试文件是否存在) 3,if语句的格式:(其中path代表条件,elif链接多个条件,最后一个条件用else表示) if pat…

    Linux干货 2017-05-22
  • IP地址之IPv4

    一、概述   IP地址有IPv4和IPv6两个版本,目前我们通常所说的IP地址是指IPv4。   IP地址由32位的二进制数组合而成,为了方便人类记忆,将二进制转换成4个十进制的数值。   在这32位数据中分为网络号与主机号两个部分。 二、IP的分级   IP网段分为五个等级,其定义如下:   A类:规定前面…

    Linux干货 2016-02-14
  • 文件的归档和压缩

    文件的归档和压缩 •一、tar命令使用 •二、其他压缩方式 •三、进程管理基本概念。 前言: 本节主要介绍文件的归档和压缩相关方法。归档和压缩有利于linux系统中文件的管理和磁盘空间的利用,善于利用归档和压缩能为我们工作中带来很多便捷。另外将简单介绍进程的一些概念,方便下一节进程管理内容的学习。 一、 tar命令使用(tar命令用于文件…

    2017-04-16
  • LVM原理、创建、扩容、缩减、快照详解

    LVM是什么?为什么要使用LVM?     LVM(Logical Volume Manager):逻辑卷管理, 在日常使用或生产环境中, 我们可能会因为在规划存储时未考虑到未来数据增长的速度超乎我们的预计而措手不及,因为增加一块硬盘再将源数据移到新硬盘上很麻烦并且提高了成本还浪费硬盘空间。   &…

    Linux干货 2016-03-09
  • ​iptables简单介绍

    iptables简单介绍 什么是防火墙? 防火墙是工作在主机或网络边缘,能够对其所匹配到的报文根据事先定义好的规则作出相应处理的组件,可以是软件,也可以是硬件,还能软硬结合实现。 UNIX/Linux中对防火墙的实现 早期在openBSD中通过内核中的ipfw实现简单的数据报过滤功能、后来在Linux 2.2内核中使用ipchains来取代,意为链、后来在L…

    Linux干货 2016-03-31