自制一个小型Linux(附带网络功能)

  我们这次讲述一下Linux启动的启动流程以及制作一个附带网络功能的mini linux

一、叙述

  在制作一个小型的Linux之前,首先你得明白Linux系统的启动过程,我们用一张图来进行说明 

wKiom1cY9_ihUml-AAIdfYZBqdU149.png

二、为什么要制作这么一个小型的系统?

  答案很简单,就是为了更好的了解Linux,当然这个没有必要了解的太深,或许你看到这个并不影响你使用并且操作一个Linux,这个也是一个兴趣。
  我们的操作系统的组成无非就是以硬件作为支撑,然后由内核来调度从而对应用程序实现系统调用,但是这个系统调用接口毕竟还是很难衔接的,也没有其它的功能,就有了公用库,程序所需要的功能都可以由他来实现,不过直接在系统调用接口上写一个程序也是可以的,说到内核,那我们就要说一内核都有什么功能,内核的功能分别是:内存管理、进程管理、网络协议管理、驱动程序、安全管理、文件系统等。

三、怎么制作

  我们是用CentOS 6为基础来制作一个Linux,我们首先在虚拟机上添加一块虚拟磁盘,添加完成其实就完成了一半,我们在系统的/mnt目录上建立两个目录,一个是boot,另一个是;sysroot

[root@CentOS6 ~]# mkdir /mnt/{boot,sysroot}

1、制作步骤

  由于磁盘是新添加的,我们使用fdisk分为两个分区,分别挂载到刚才/mnt/boot和/mnt/sysroot中。

[root@CentOS6 ~]# fdisk /dev/sdb

  使用fdisk建立磁盘分区完成之后,我们把磁盘进行格式化为ext4的分区,挂载到boot和sysroot目录中。

# mkfs.ext4 /dev/sdb1 # mkfs.ext4 /dev/sdb2 # mount /dev/sdb1 /mnt/boot # mount /dev/sdb2 /mnt/sysroot

  之后我们在新磁盘上安装grub

[root@CentOS6 ~]# grub-install --root-directory=/mnt/ /dev/sdb

  从/boot分区中复制 vmlinuz-VERSIONinitramfs-VERSION两个文件,一个是内核文件,另一个是内核所加载的驱动程序(里面含有模拟的根),复制完成后重新命令为vmlinuz和initramfs.img

[root@CentOS6 ~]# cp /boot/vmlinuz-2.6.32-358.el6.x86_64 /mnt/boot/vmlinuz [root@CentOS6 ~]# cp /boot/initramfs-2.6.32-358.el6.x86_64.img /mnt/boot/initramfs.img

  之后我们在/mnt/boot/grub的目录中新建一个文件叫grub.conf,内容格式如下:

[root@CentOS6 ~]# vim /mnt/boot/grub/grub.conf default=0 timeout=5 title CentOS 6.4     root (hd0,0)     kernel /vmlinuz ro requiet root=/dev/sda2 selinux=0 init=/bin/bash    initrd /initramfs.img     chroot /mnt/sysroot

  之后创建目录在/mnt/sysroot上(必须有,不然启动不了)

[root@CentOS6 ~]# mkdir -pv /mnt/sysroot/{etc,lib,lib64,bin,sbin,tmp,var,usr,sys,proc,opt,home,root,boot,dev,mnt,media}

  用脚本复制相关的命令和库文件,复制完成之后启动看看,如果出错,请更改,以上的步骤如果你成功,可以添加网络功能了。复制命令脚本如下:

#!/bin/bash 
# Author:liu 
target=/mnt/sysroot 
clearCmd(){
    if which $cmd &>/dev/null;then
        cmdPath=`which --skip-alias $cmd`
    else
      echo "No such command."
      return 5     
    fi
} 
cmdCopy(){     
    cmdDir=`dirname $1`     
    [ -d ${target}${cmdDir} ] || mkdir -p ${target}${cmdDir}     
    [ -f ${target}${1} ] || cp $1 ${target}${cmdDir} 
} 
libCopy(){    
    for lib in `ldd $1 | grep -o "/[^[:space:]]\{1,\}"`;do
        libDir=`dirname $lib`        
        [ -d ${target}${libDir} ] || mkdir -p ${target}${libDir}
        [ -f ${target}${lib} ] || cp $lib ${target}${libDir}     
    done 
} 
while true;do
    read -p "Please input command: " cmd
    [[ "$cmd" == "quit" ]] && echo "quit" && exit 0
    clearCmd $cmd [ $? -eq 5 ] && continue  
    cmdCopy $cmdPath  
    libCopy $cmdPath
done

  将宿主机暂停,然后创建新的虚拟机将虚拟磁盘添加进新的虚拟机中。

%L)LL3I}JPH6I2ZIDV$RNQL.png 

  以上步骤成功,开始添加我们的网络功能吧!

2、将虚拟机添加网络功能

  首先我们先更改一下grub.conf(注意:是在/mnt/boot目录下),将原来的init=/bin/bash更改为init=/sbin/init

default=0 
timeout=5
    title CentOS 6.4    
    root (hd0,0)     
    kernel /vmlinuz ro requiet root=/dev/sda2 selinux=0 init=/sbin/init    
    initrd /initramfs.img   
    chroot /mnt/sysroot

  然后我们在/mnt/sysroot/sbin目录写一个脚本,名字叫做init,写作格式如下:

[root@CentOS6 ~]# vim /mnt/sysroot/sbin/init 
#!/bin/bash 
# 
mount -n -t proc proc /proc 
mount -n -t sysfs sysfs /sys mount -n -o remount,rw /dev/sda2 
[[ $? -eq 0 ]] && echo "The / is success" 
insmod /lib64/e1000.ko ifconfig eth0 172.16.42.29/16 
ifconfig lo 127.0.0.1/8 /bin/bash

  找到宿主机网络模块e1000.ko所在的位置并拷贝到/mnt/sysroot/lib64目录下(注意:在虚拟机中网卡的模块叫做e1000可以用dmsg命令查看你的网卡的模块名称是什么)。

[root@CentOS6 ~]# dmesg | grep -i eth0 
[root@CentOS6 ~]# modinfo -n e1000 
/lib/modules/2.6.32-358.el6.x86_64/kernel/drivers/net/e1000/e1000.ko
[root@CentOS6 ~]# cp /lib/modules/2.6.32-358.el6.x86_64/kernel/drivers/net/e1000/e1000.ko /mnt/sysroot/lib64/

  保存并退出之后我们继续利用复制命令脚本把相关命令复制进去(例如:ifconfig,nsmod,rmmod,reboot,ping等) 之后我们再一次启动。 

7KM)9@N~ZL]25UT1MLR7~B0.png

 
  如果成功了,那我恭喜你。

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

(0)
刘 祥宇刘 祥宇
上一篇 2016-12-21 09:52
下一篇 2016-12-21 11:27

相关推荐

  • N27_第一周作业

    一、描述计算机的组成及其功能 计算机由CPU、内存、输入设备和输出设备组成。 CPU:运算器、控制器、寄存器、缓存 *运算器:进行数字运算和逻辑运算。 *控制器: A、从内存中取出一条指令,并指出下一条指令在内存中的位置; B、对指令进行译码或测试,并产生相应的操作控制信号; C、控制并控制CPU、内存和输入/输出设备之间数据流动的方向。 *寄存器:暂存指令…

    Linux干货 2017-09-04
  • tar,cpio,rpm,yum的使用详解(适合初学者)

    基于linux下的tar包管理和yum源配置 友情提示:对于这些实际操作的,还是需要进行手工的尝试,由于这几个对于包管理的是比较常用和实用的, 所以,一定要熟练使用。 1.tar tar是对于系统中文件,目录等进行打包,解包的工具。tar也可以对文件进行打包存放到别的目录下, 所以在很早的时候,一些老的工程师经常使用tar对文件进行备份。很大程度上,所谓的t…

    Linux干货 2016-08-21
  • 说说web和http以及lamp/lnmp

    <span style="font-size: 24px;font-family: 宋体,SimSun">**说说web和http以及lamp/lnmp**</span> 说说web和http以及lamp/lnmp 在这篇文章当中你将看到如下内容: web与http的简介,网页的分类 度量网站流量的几个术语——知道…

    2016-05-28
  • vsftpd

    练习:完成vsftpd配置 (1) 禁锢系统用户于家目录 [root@node3 ~]# yum -y install vsftpd [root@node3 ~]# vim /etc/vsftpd/vsftpd.conf chroot_local_user=YES &n…

    Linux干货 2016-10-16
  • N25_第六周作业

    1、复制/etc/rc.d/rc.sysinit文件至tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; :%s@^[[:space:]]\+@#&@g(CentOS7下并未看到这个文件) 2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;…

    Linux干货 2017-02-15
  • 重定向与管道

         本次内容    1.三种I/O设备    2.把I/O从定向入文件    3.命令tr    4.使用管道链接命令    5.tee   我们都知道程序是由:指令+数据    &n…

    2017-07-23