diy自己的linux

  1. 准备一台liunx的机器,我用的是liunx虚拟机

  2. 单独加载一块硬盘,我加载了一块20G的硬盘,然后用fdisk /dev/sdb进行分区,sdb1用来作为将来系统的/boot分区,所有100M就可以了,sdb2用来作为将来系统的/分区,我给了10G。然后将两个分区格式化为ext4系统。

  3. mkdir /mnt/boot

    mkdir /mnt/sdc2

    mount /dev/sdb1 /mnt/boot

    mount /dev/sdb2 /mnt/sdc2

    wKioL1fT4zWRWZhsAABMXri2n-Q444.jpg

4.执行grub-install命令,黄色箭头是指将来要作为/ 的目录,红色箭头是表示将grub相关文件写入/sdb磁盘中(grub相关文件是用来引导启动内核的关键文件)

wKioL1fT5YnwHc9RAAASxJCMQNQ554.jpg

5.拷贝内核文件和文件系统文件到/boot

wKiom1fT58Cxsv0CAAAaYZZ4cMM678.jpg

6.编辑/mnt/boot/grub/grub.conf文件

wKiom1fT6S-AnlWEAAAoy9TbgIo778.jpg

第一行:出现列表时,背景图片的路径(图片的制作方法请看我相关的文章)

第二行:内核的名字

第三行:将来从第一块硬盘第一个扇区启动

第四行:启动内核文件,只读,/目录在/dev/sda2分区 此时selinux关闭 init程序读取/bin/bash

第五行:根目录可用前的一个临时文件系统,initrd与内核绑定在一起,并作为内核引导过程的一部分进行加载。内核然后会将这个 initrd文件作为其两阶段引导过程的一部分来加载模块,这样才能稍后使用真正的文件系统,并挂载实际的根文件系统。

7.写挂载文件

wKiom1fT7QjC6H5IAAAbvfupWqs499.jpg

8.在/mnt/sdc2/下建根目录中的文件夹

wKioL1fT8Z6C9lbvAAAcynQndHg665.jpg

9.利用脚本拷一些命令到新的目录下(在/mnt/sdc2下执行此命令)

wKioL1fT8pmjB_ewAABi41IjshU563.jpg

脚本内容如下:


#!/bin/bash



ch_root="/mnt/sdc2"

[ ! -d $ch_root ] && mkdir $ch_root


bincopy() {

    if which $1 &>/dev/null; then


        local cmd_path=`which –skip-alias $1`

        local bin_dir=`dirname $cmd_path`

        [ -d ${ch_root}${bin_dir} ] || mkdir -p ${ch_root}${bin_dir}

        [ -f ${ch_root}${cmd_path} ] || cp $cmd_path ${ch_root}${bin_dir}

        return 0

    else

        echo "Command not found."

        return 1

    fi

}



ch_root="/mnt/sdc2"

[ ! -d $ch_root ] && mkdir $ch_root


bincopy() {

    if which $1 &>/dev/null; then


        local cmd_path=`which –skip-alias $1`

        local bin_dir=`dirname $cmd_path`

        [ -d ${ch_root}${bin_dir} ] || mkdir -p ${ch_root}${bin_dir}

        [ -f ${ch_root}${cmd_path} ] || cp $cmd_path ${ch_root}${bin_dir}

        return 0

    else

        echo "Command not found."

        return 1

    fi

}


libcopy() {

    local lib_list=$(ldd `which –skip-alias $1` | grep -Eo '/[^[:space:]]+')

    for loop in $lib_list;do

        local lib_dir=`dirname $loop`

        [ -d ${ch_root}${lib_dir} ] || mkdir -p  ${ch_root}${lib_dir}

        [ -f ${ch_root}${loop} ] || cp $loop ${ch_root}${lib_dir}

    done

}



read -p "Please input a command or quit: " command


while [ "$command" != "quit" ];do

    if bincopy $command ;then

        libcopy $command

    fi

    read -p "Please input a command or quit: " command

done


10.我们此时可以将此块硬盘取下,挂载到一个新的liunx系统中去,测试是否能正常启动

wKiom1fT86LSN4LHAACkVmE8E00759.jpg

新虚拟机

wKioL1fT9FTASiA3AAB7G9-yGXg617.jpg

11.启动新的虚拟机

wKiom1fT9LTzV6DbAADcGxP6Tkk264.jpg

此时,我们可以看到内核的名字是zebralinux,也就是我们在/mnt/boot/grub/grub.conf中title所对应的行,背景图片也被换了,说明暂时系统是好的,可以继续进行

wKiom1fT9ZPAaCWIAAAcuaLhJAg278.jpg

因为我们制定init=/bin/bash,所有开机后执行的第一个程序就进入到bash中,在此界面中我们可以测试其他命令,有些命令应该可用,有些有依赖其他文件的命令或许此刻或用不了,我们只是做了个简单linux。

wKioL1fT9xbgVaO9AADLtiIkPGc875.jpg我们第一次mount时,sda1没有被挂载上。当我们挂载时,会报错,但仍能被挂载上。之后,我们就可以进入到/下的目录和/boot目录中了

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

(0)
zebra930zebra930
上一篇 2016-09-14
下一篇 2016-09-14

相关推荐

  • Hadoop伪分布式模型

    # java -version # vim /etc/profile.d/java.sh export JAVA_HOME=/usr # yum install java-1.8.0-openjdk-devel # mkdir /bdapps # tar xf hadoop-2.7.4.tar.gz -C /bdapps/ # cd /bdapps # ln…

    2017-12-08
  • Linux-Centos7编译内核

    编译内核     前提:         (1)准备好开发环境         (2) 获取目标主机上硬件设备的相关信息         (3) 获取目标主机系统功能的相关信息       …

    2017-07-16
  • nmcli命令用法简介

    nmcli:地址配置工具 用法:nmcli [OPTIONS] OBJECT { COMMAND | help } 一般使用的情况有: 设备:正在使用的网络端口 链接:一组配置设置,对于一个单一的设备可以有多个连接,可以在链接之间切换 常用命令:     nmcli connection show &nbsp…

    Linux干货 2016-09-07
  • linux系统启动之破坏与修复

    linux系统启动之破坏与修复:      通过这些实验,了解linux启动流程和相关文件,同时也预防系统发生问题能更快解决,而不用重装或者耽误时间:      实验:破坏MBR 446     dd if=/dev/zero of=/dev/sda bs=1 count=446…

    Linux干货 2017-03-30
  • bash特性及bash脚本编程初步

    bash特性之命令hash 之前我们讲过用户在执行一个命令的时候bash会遍历环境变量$PATH中所有路径来查找执行文件。而命令hash是用来缓存之前用户使用过的命令下次执行的时候直接搜索hash缓存来减少对$PATH变量中路径的遍历次数,从而提高系统运行效率 hash:hash命令     hash:列出 &nbsp…

    Linux干货 2016-12-20
  • Openssl搭建私有CA认证

    概述 CA英文全称Certification Authority,即数字证书认机构。从广义上来说,CA是负责发放和管理数字证书的权威机构,并作为用户数字认证中受信任的第三方,承担公钥体系(PKI)中公钥的合法性检验的责任,在互联网上,实现用户与用户、用户与企业之间的数字身份认证。 本文通过使用openssl进行搭建私有CA认证体系,从而简单地了解CA的认证过…

    Linux干货 2016-09-22