私人定制—linux系统

自制Linux系统:

1、分区并创建文件系统

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

分两个必要的分区

/dev/sdb1对应/boot /dev/sdb2对应根/

创建文件系统:

[root@localhost6 ~]# mkfs.ext4 /dev/sdb1
[root@localhost6 ~]# mkfs.ext4 /dev/sdb2

2、创建挂载点,并挂载boot

[root@localhost6 ~]# mkdir/mnt/boot
[root@localhost6 ~]# mount /dev/sdb1 /mnt/boot

3、安装grub,生成grub文件

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

wKioL1fbXY3QWc0nAAAT2PlX1Bo997.png

4、建立grub.conf:

[root@localhost6 ~]# vim /mnt/boot/grub/grub.conf
default=0
timeout=3
title mylinux
    root (hd0,0)
    kernel /vmlinuz-2.6.32-642.el6.x86_64 root=/dev/sda2 selinux=0 init=/bin/bash 
    initrd /initramfs-2.6.32-642.el6.x86_64.img

5、恢复内核和initramfs文件

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

wKiom1fbX9Tj49aVAAAlhI0v-PM339.png

6、创建一级目录

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

wKioL1fbYPqCl9v3AAAR3lGTkto147.png

7、编辑fstab文件

[root@localhost6 ~]# vim /mnt/sysroot/etc/fstab
/dev/sda1 /boot ext4 defaults 1 1
/dev/sda2  /    ext4 defaults 1 2

8、复制bash,相关命令和相关库文件

由于文件较多,一个一个复制较为麻烦,所以建议使用脚本,来实现复制任务。

[root@localhost6 ~]# vim copycmd.sh
#!/bin/bash

ch_root="/mnt/sysroot"
[ ! -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: " command

while [ "$command" != "quit" ];do
    if bincopy $command ;then
        libcopy $command
    fi
    read -p "Please input a command or quit: " command
done

wKiom1fbadmgy1XbAAAXEVfWgCo546.png

9,现在一个晓得linux已经制作完成,它只有很简单的功能,但是,以后有需要可以再添加其他的功能。下面我们来开机看一下。

wKiom1fbfHeAKz5bAAtzUSuSnGw946.gif

这样,一个简单的小linux已经制作完成,可以将它放在U盘等便携式设备上,可以随时使用,修改等。。。

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

(0)
GrootGroot
上一篇 2016-09-26
下一篇 2016-09-26

相关推荐

  • N26-第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost ~]# cp -rfp /etc/skel/ /home/tuser1[root@localhost ~]# chmod 700 /home/tuser1 2、编辑/etc/group文件,添…

    Linux干货 2017-02-25
  • N26-博客作业-week11

    1、详细描述一次加密通讯的过程,结合图示最佳。 加密过程 1、先用单向加密算法计算出数据的特征码 2、私钥加密特征码,并将结果附加在数据之后 3、生成一个临时的对称密钥,并使用对称密钥加密整段数据 4、获取对方的公钥,使用该公钥加密之前生成的临时对称密钥,并附加在数据之后 5、将所有数据发送给对方解密过程 1、先使用私钥解密加密的对称密钥 2、用对称密钥解密…

    2017-04-18
  • 基于BIND实现的DNS正反解析及主从DNS的配置

    基于BIND实现的DNS正反解析及主从DNS的配置 标签: DNS正反解析 DNS主从复制 测试环境 准备2台虚拟机,一台为主DNS,IP地址为:192.168.103.161。另一台为从DNS,IP地址为:192.168.103.162两台都装好bind,所需包有:bind,bind-utils,bind-libs 主DNS的配置文件 配置主文件/etc/…

    Linux干货 2016-04-11
  • swap与dd命令使用详解

    处理交换文件和分区     交换分区是系统RAM 的补充 基本设置包括:     创建交换分区或者文件     使用mkswap 写入特殊签名     在/etc/fstab 文件中添加适当的条目 &…

    Linux干货 2017-04-30
  • vim编辑器

    导读:      本章将主要介绍Linux中的一种常用文本编辑器vim,具体内容如下:       □使用vi和vim的三种主要模式       移动光标,进入插入模式       改变、删除、复制文本     &n…

    Linux干货 2016-08-15
  • 马哥教育网络21期+第七周练习博客

    马哥教育网络21期+第七周练习博客 1、创建一个10G分区,并格式为ext4文件系统; 首先挂载一个新的硬盘使用fdisk /dev/sdb进入相应的磁盘空间划分一个10G的磁盘空间; Command (m for help): n Command action    …

    Linux干货 2016-08-22

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-26 11:56

    写的不错,操作性性很强,整个流程很顺畅。