自制一个小型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

相关推荐

  • 马哥教育网络班21期第11周课程练习

    1、详细描述一次加密通讯的过程,结合图示最佳。 发送方Bob:自上至下 1、生成数据 2、Bob用单向加密算法对数据提取特征码 3、Bob用自己的私钥加密特征码,并附加在数据后面 4、Bob使用对称加密算法生成临时会话密钥加密特征码和数据 5、Bob用Alice的公钥加密临时会话密钥,并附加在数据后 接收方Alice:自下至上 1、Alice收到Bob数据,…

    Linux干货 2016-10-31
  • socket阻塞与非阻塞,同步与异步、I/O模型

    1. 概念理解      在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式:同步:      所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。也就是必须一件一件事做,等前…

    Linux干货 2015-04-10
  • 交换分区管理

    创建交换分区 linux上的交换分区必须使用独立的文件系统且文件系统的systemid必须为82mkswap [options] device [size] 创建交换分区文件系统 挂载交换分区     swapon 设备名称 处理交换文件和分区     交换分区是系统RAM的补充  &nb…

    Linux干货 2016-09-02
  • Tomcat相关知识整理

    初识Servlet SUN公司制定了一系列Web应用与Web服务器进行协作的标准Java接口,统称为Java Servlet API,还对Web服务器发布及运行Web应用的一些细节做了规约。SUN公司把这一系列标准Java接口和规约统称为Servlet规范。Servlet就是Web服务器与Web应用进行协作的标准接口。 Servlet规范把能够发布和运行Ja…

    Linux干货 2016-12-05
  • 马哥教育网络19期+第十四周课程练习

    系统的INPUT和OUTPUT默认策略为DROP; 先把策略设置为DROP # iptables -t filter -P OUTPUT DROP # iptables -t filter -P INPUT DROP 1、限制本地主机的we…

    Linux干货 2016-08-22
  • 1019作业

    1019作业 柴震 软连接 硬连接 软连接和硬链接的区别 属性与定义: 硬链接:新建的文件是已经存在的文件的一个别名,所以创建时链接数递增;而且当原文件删除时,新建的链接文件仍然可以使用,因其直接对应于数据块。 软链接:也称为符号链接。新建的链接文件以“路径”的形式来表示另一个文件,其大小为指向的路径字符串的长度,不增加或减少目标文件in…

    Linux干货 2016-10-19