总结之:CentOS 6.4系统裁减详解及装载网卡步骤

2024-09-05 12:58

本文主要是介绍总结之:CentOS 6.4系统裁减详解及装载网卡步骤,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原创作品,允许转载,转载时请务必以超链接形式标明文章  原始出处 、作者信息和本声明。否则将追究法律责任。 http://tanxw.blog.51cto.com/4309543/1368801

前言
   随着接触Linux的慢慢深入、对Linux也有了一个基本认识了吧,慢慢的接触系统内核、系统配置文件、在了解Linux的系统启动流程后,现在来总结一下一个简单的Linux系统的裁减方法和步骤,一个只有内核文件和几个简单的命令的小Linux系统,现在就开始以下裁减:

正文 
   首先在一个虚拟机上新增一块硬盘、这样等裁减好了之后可以把这块硬盘挂载到别的虚拟机上去、运行自已裁减的那个Linux系统;

wKioL1MW6cOB-EHAAAGPeEDJ9iQ811.jpg

wKioL1MW6cejrXyuAAIgtdPsFkM192.jpg

wKiom1MW6e-B2P3OAAF9-XUwsEc625.jpg

wKioL1MW6c6Ss1qjAAEZKYfTnis903.jpg

wKioL1MW6duSTyg1AAEumrbayV0149.jpg



   添加完硬盘后就启动虚拟机了;    


   查找一下刚才添加的硬盘:
   # fdisk -l /dev/sd[a-z]

wKioL1MW6mzz2W_CAAD0OCsStpg036.jpg


   添加完硬盘之后就应该分区格式化硬盘了;
   # fdisk /dev/sdb

   这里就自己分区好了、很简单的、比windows简单多了!!!

   分区完后就给这两个分区格式化了;
   格式化指定文件系统类型为ext4
   # mke2fs -t ext4 /dev/sdb1
   # mke2fs -t ext4 /dev/sdb2

wKioL1MW6xyAIpb_AAB97b2jK_Y110.jpg


   格式化完了之后就看到刚才分的两个分区列表了;

   而后在/mnt目录下创建两个目录分别挂载到刚分好的那两个分区上去:
   # mkdir -pv /mnt/{boot,sysroot}


   挂载目录/mnt/boot到/dev/sdb1分区上去;
   挂载目录/mnt/sysroot到/dev/sdb2分区上去;
   # mount /dev/sdb1 /mnt/boot/
   # mount /dev/sdb2 /mnt/sysroot/

wKiom1MW64viHnRKAAEdUcbC910790.jpg


   而后就往sdb上安装grub;
   创建的boot在哪就指定到哪个路径下去,然后再指定安装在哪块硬盘上,grub安装完之后就会生成/mnt/boot/grub/目录、grub目录下就会生成相关的文件
   # grub-install --root-directory=/mnt /dev/sdb

wKiom1MW67_RaaJFAAE0HARIVEs807.jpg

wKiom1MW7DbCm7Z-AADhvPLKxe8781.jpg


   现在我们把宿主机里的内核文件给sdb拷贝一份到/mnt/boot/目录下,名字我们就叫mvlinuz、版本号我们就不带了、init文件也拷贝一份到/mnt/boot/目录下,名字就简单的改为initramfs.img
   # cp /boot/vmlinuz-2.6.32-431.el6.x86_64 /mnt/boot/vmlinuz
   # cp /boot/initramfs-2.6.32-431.el6.x86_64.img /mnt/boot/initramfs.img

wKiom1MW7FXwj2gKAADiJhm3tYc730.jpg

   完整的linux有哪些目录呢、那我们就得来创建一下这些个目录了;之前我们挂载的那个sysroot的目录都没有到、那我们就在这个目录下创建这些目录、切换到/mnt/sysroot/下:
   # mkdir -pv /etc/rc.d root boot dev proc sys tmp var usr srv lib lib64 bin sbin home mnt media

wKiom1MW7KXhuVHdAABPNoOCSS4284.jpg

   到这里了、如果我们的第二块硬盘上再有个可执行程序是不是就可以运行了呢、那我们不仿移植一些程序到我们的第二块硬盘上去、我们之前写了一个移植可执行程序的脚本、包括程序所依赖的库文件也一并移植过去了、代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/bin/bash
#
#定义目标目录、也就是要拷贝到的那个目录
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  "Enter a command: "  cmd
   if  "$cmd"  ==  'quit'  ] ; then
         echo  "quit"
         exit  0
   fi
   #调用清理命令方法
   clearCmd $cmd
   [ $? - eq  5 ] &&  continue
   #调用拷贝命令和库文件的方法
   cmdCopy $cmdPath
   libCopy $cmdPath
done


wKioL1MW77zCBKyQAAFBsoEDZCE400.jpg

wKioL1MW8B-SiUDtAACmR-uljKg736.jpg

   接着切换到/mnt/sysroot/bin/目录下、给bash创建一个软链接、因为系统默认找shell都是找sh
   # ln -sv bash sh    

   现在我们切换到/mnt/sysroot/目录试一下看就知道了:
   # chroot /mnt/sysroot/

wKiom1MW8L3gz8-gAACRqZOTlL8973.jpg


   看、我们的小根可以用了    
   这里我们再提供一个init脚本给这个小系统,在/sbin/目录下,这个init要通过调用/etc/inittab这个配置文件,然后再去执行/etc/rc.d/rc.sysinit下的初始化脚本、这样的话那我们就把初始化脚本的内容拿到init里来执行;

   这个脚本到底要做哪些操作呢:

   # vim /mnt/sysroot/sbin/init

1
2
3
4
5
6
7
8
9
10
11
#!/bin/bash
#
#打印欢迎信息
echo  -e  "\tWecome to \033[34m Mini Linux-2.6 OS\033[0m"
#挂载两个伪文件系统;-t后面跟文件系统类型
mount  -n -t proc proc  /proc
mount  -n -t sysfs sysfs  /sys
  #启动后再以读写方式重新挂载/dev/sda2上,这样的话就要把宿主机关机再后再新运行这个小系统了
mount  -n -o remount,rw  /dev/sda2  /
#运行bin下的bash
/bin/bash


   保存退出后给init一个可执行权限:
   chmod +x /mnt/sysroot/sbin/init
   此时我们就要给这块硬盘上的小系统提供一个grub的配置文件了,如果不写这个配置文件也可以启动、但一进入就会进到grub小shell中让你配置系统的grub信息;
   # vim /mnt/boot/grub/grub.conf

1
2
3
4
5
6
default=0
timeout=5
title Mini Linux OS
     root(hd0,0)
     kernel  /vmlinuz  ro root= /dev/sda2  selinux=0 init= /sbin/init
     initrd  /initramfs .img


   OK,保存退出!        

   同步一下到对应的磁盘上:
   # sync    
   经过以上的操作、下面我们就来创建一个新的虚拟机、然后选择虚拟机使用我们刚才装小系统的那块硬盘、CentOS_SecondSCSI.vmdk;

wKioL1MW8-CD_ojRAAH2able-f0277.jpg
   好了、我们把已经运行的虚拟机都挂载起,运行我们刚才创建好的那个有CentOS_SecondSCSI.vmdk磁盘的虚拟机,到这里我们就看到我们裁减的小系统跑起来了、看到我们自己定义的Min Linux-2.6 OS了!    wKioL1MW9GLQHBi0AABl_cHytmI133.jpg

进到我们的小系统里去了:

wKiom1MXATDhooQGAABLZHNpUzs579.jpg


   接下来我们要在小系统里装载网卡、但是要确保被装载的网卡驱动没有使用、我们可以用lsmod这个命令查看一下:这里以e1000为例来说明问题、我这里的虚拟机上已经装有了、那我就先卸载了再装载上去:

   在宿主机上查看当前内核装载的模块信息:
   # lsmod

   卸载e1000网卡驱动:
   # modprobe -r e1000

   要装载的话用下面命令即可:
   # modprobe e1000

   那怎么样把e1000的内核模块拷贝到我们的小系统里面里、让他装上去、并且启用网络功能呢、首先确保我们系统中的piv4没有做成模块,这里我们的ipv4没有做成模块、那就去移植这个模块吧:
   首先给他创建一个目录、切换到/mnt/sysroot/lib目录中:
   # mkdir modules

   再拷贝我们系统上的内核模块到这个目录里去
   # cp /lib/modules/2.6.32-431.el6.x86_64/kernel/drivers/net/e1000/e1000.ko /mnt/sysroot/lib/modules/

   再移植一些所需要用到的命令:insmod、rmmod、ifconfig、ip、ping

   OK、同步一下我们就可以重新启动小系统了
   # sync

   进到小系统里、敲命令吧;
   # insmod /lib/modules/e1000.ko
   # ifocnfig eth0 176.16.251.100/16
   # ping -c 3 176.16.251.100
wKioL1MXAfLx2_ZuAAFwEvAOYU4644.jpg

wKiom1MXA0LRw9JvAADu3n6P1sw699.jpg

wKioL1MXAxzjKk7rAAFg5pXqsEk919.jpg


   好了、到这里我们就基本完成了小系统的裁减了、要想装载更多的功能、后面可以自己再添加、想装什么就装什么、要想系统启动就有网络那可以在init中设置一下、在init中加上ifconfig eth0 176.16.251.100/16就可以了、init要写得更好自己后期再慢慢改吧、加慢判断和显示颜色什么的等等:

结语:
   好像东西很多的样子、其实也不是很多了、可能我比较啰嗦、噼里啪啦的写了一大堆吧、其实操作也不多、就是要理清步骤就很清晰了、不是吗、好吧、就到此结束吧、人无完人、有错或有什么不妥还望大神指点哦!

这篇关于总结之:CentOS 6.4系统裁减详解及装载网卡步骤的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1139031

相关文章

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

SQL Server 中的 WITH (NOLOCK) 示例详解

《SQLServer中的WITH(NOLOCK)示例详解》SQLServer中的WITH(NOLOCK)是一种表提示,等同于READUNCOMMITTED隔离级别,允许查询在不获取共享锁的情... 目录SQL Server 中的 WITH (NOLOCK) 详解一、WITH (NOLOCK) 的本质二、工作

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原