linux基础21定制linux系统
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux基础21定制linux系统相关的知识,希望对你有一定的参考价值。
一、基于HOST(宿主机)制作一个简单的可启动的linux
1、给目标磁盘分区
两个:
宿主机上:/dev/sdb1,/dev/sdb2
/dev/sdb1挂载至/mnt/boot,/dev/sdb2挂载至/mnt/sysroot
2、安装grub至目标磁盘
# grub-install --root-directory=/mnt /dev/sdb
3、复制内核和initrd文件
# cp /boot/vmlinz-VERSION /mnt/boot/vmlinuz
# cp /boot/initramfs-VERSION.img /mnt/boot/initramfs.img
注意:复制到目标机的文件为方便在这里才没有写版本,建议写版本也要写上
4、创建目标主机的根文件系统
# mkdir -pv /mnt/sysroot/{etc/rc.d,usr,var,proc,sys,dev,lib,lib64,bin,sbin,boot,srv,mnt,media,home,root}
接着移植bash,ls,cat等常用命令至目标主机的根文件系统
5、为grub提供配置文件
# vim /mnt/boot/grub/grub.conf
default=0
timeout=5
title Magedu Little linux
root (hd0,0)
kernel /vmlinuz ro root=/dev/sda2 quiet selinux=0 init=/bin/bash
initrd /initramfs.img
就完成了基于HOST制作一个简单的可启动的linux,将此硬盘拆下安装到别的机器上(因为没有驱动,只能在虚拟机上运行),测试启动
6、用脚本代替/sbin/init
使用脚本替代/sbin/init实现简单的功能:
如打印欢迎信息,以读写方式重新挂载根文件系统,挂载/etc/fstab文件中定义的需要挂载的设备,
实战:
[[email protected] ~]# fdisk -l /dev/sdb Disk /dev/sdb: 21.5 GB, 21474836480 bytes 255 heads, 63 sectors/track, 2610 cylinders Units = cylinders of 16065 * 512 = 8225280 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk identifier: 0xf3b882a4 Device Boot Start End Blocks Id System /dev/sdb1 1 500 4016218+ 83 Linux /dev/sdb2 501 632 1060290 83 Linux [[email protected] ~]# mkdir /mnt/{boot,sysroot} [[email protected] ~]# mount /dev/sdb1 /mnt/boot [[email protected] ~]# mount /dev/sdb2 /mnt/sysroot [[email protected] ~]# df -TH Filesystem Type Size Used Avail Use% Mounted on /dev/sda2 ext4 20G 4.9G 14G 27% / tmpfs tmpfs 981M 0 981M 0% /dev/shm /dev/sda1 ext4 508M 34M 448M 7% /boot /dev/sdc1 ext4 3.0T 211M 2.9T 1% /mnt /dev/sdb1 ext4 4.1G 76M 3.8G 2% /mnt/boot /dev/sdb2 ext4 1.1G 35M 980M 4% /mnt/sysroot [[email protected] ~]# cp /boot/vmlinuz-2.6.32-431.el6.x86_64 /mnt/boot/vmlinuz [[email protected] ~]# cp /boot/initramfs-2.6.32-431.el6.x86_64.img /mnt/boot/initramfs [[email protected] ~]# grub-install --root-directory=/mnt /dev/sdb Probing devices to guess Bios drives. This may take a long time. Installation finished. No error reported. This is the contents of the device map /mnt/boot/grub/device.map. Check if this is correct or not. If any of the lines is incorrect, fix it and re-run the script `grub-install‘. (fd0) /dev/fd0 (hd0) /dev/sda (hd1) /dev/sdb (hd2) /dev/sdc [[email protected] ~]# ls /mnt/boot grub initramfs lost+found vmlinuz [[email protected] ~]# vim /mnt/boot/grub/grub.conf [[email protected] ~]# cat /mnt/boot/grub/grub.conf #boot分区就完成了 default=0 timeout=10 titile Anyfish Linux root (hd0,0) kernel /vmlinuz ro root=/dev/sda2 quiet selinux=0 init=/bin/bash initrd /initramfs #init=bash指定kernel不再去查询init,直接启动bash,不设置kernel找不到init就会报错,这里quiet不能写在selinue=0或init=/bin/bash之后,否则系统还是会去查找init #下面开始准备根文件系统 [[email protected] ~]# mkdir -pv /mnt/sysroot/{etc/rc.d,usr,var,proc,sys,dev,lib,lib64,bin,sbin,boot,home,mnt} mkdir: 已创建目录 "/mnt/sysroot/etc" mkdir: 已创建目录 "/mnt/sysroot/etc/rc.d" mkdir: 已创建目录 "/mnt/sysroot/usr" mkdir: 已创建目录 "/mnt/sysroot/var" mkdir: 已创建目录 "/mnt/sysroot/proc" mkdir: 已创建目录 "/mnt/sysroot/sys" mkdir: 已创建目录 "/mnt/sysroot/dev" mkdir: 已创建目录 "/mnt/sysroot/lib" mkdir: 已创建目录 "/mnt/sysroot/lib64" mkdir: 已创建目录 "/mnt/sysroot/bin" mkdir: 已创建目录 "/mnt/sysroot/sbin" mkdir: 已创建目录 "/mnt/sysroot/boot" mkdir: 已创建目录 "/mnt/sysroot/home" mkdir: 已创建目录 "/mnt/sysroot/mnt" [[email protected] ~]# cp /bin/bash /mnt/sysroot/bin [[email protected] ~]# chroot /mnt/sysroot chroot: failed to run command `/bin/bash‘: No such file or directory [[email protected] ~]# ls /mnt/sysroot/bin/bash /mnt/sysroot/bin/bash [[email protected] ~]# ldd /bin/bash linux-vdso.so.1 => (0x00007fff43b8e000) libtinfo.so.5 => /lib64/libtinfo.so.5 (0x00007f08cb011000) libdl.so.2 => /lib64/libdl.so.2 (0x00007f08cae0d000) libc.so.6 => /lib64/libc.so.6 (0x00007f08caa78000) /lib64/ld-linux-x86-64.so.2 (0x00007f08cb242000) [[email protected] ~]# ldd /bin/bash|grep -o ‘/[[:alnum:]/.-]\+‘ /lib64/libtinfo.so.5 /lib64/libdl.so.2 /lib64/libc.so.6 /lib64/ld-linux-x86-64.so.2 [[email protected] ~]# for i in `ldd /bin/bash|grep -o ‘/[[:alnum:]/.-]\+‘|cut -d/ -f3`;do cp /lib64/$i /mnt/sysroot/lib64/;done [[email protected] ~]# ls /mnt/sysroot/lib64/ ld-linux-x86-64.so.2 libc.so.6 libdl.so.2 libtinfo.so.5 [[email protected] ~]# chroot /mnt/sysroot bash-4.1# ls bash: ls: command not found bash-4.1# bash-4.1# quit bash: quit: command not found bash-4.1# exit exit #这里需要注意:chroot切换根目录的目录下一定要有bin/bash才能切换成功,命令成功运行需要自身依赖的库文件 [[email protected] ~]# cp /bin/ls /bin/cat /mnt/sysroot/bin [[email protected] ~]# ls /mnt/sysroot/bin bash cat ls [[email protected] ~]# ldd /bin/cat #cat依赖的库文件和bash一样,已经有了 linux-vdso.so.1 => (0x00007fff219ff000) libc.so.6 => /lib64/libc.so.6 (0x00007fcfd1c9b000) /lib64/ld-linux-x86-64.so.2 (0x00007fcfd203f000) [[email protected] ~]# cp /lib64/libc.so.6 ^C [[email protected] ~]# ldd /bin/ls linux-vdso.so.1 => (0x00007fffa578d000) libselinux.so.1 => /lib64/libselinux.so.1 (0x00007fbac4e29000) librt.so.1 => /lib64/librt.so.1 (0x00007fbac4c21000) libcap.so.2 => /lib64/libcap.so.2 (0x00007fbac4a1c000) libacl.so.1 => /lib64/libacl.so.1 (0x00007fbac4814000) libc.so.6 => /lib64/libc.so.6 (0x00007fbac4480000) libdl.so.2 => /lib64/libdl.so.2 (0x00007fbac427b000) /lib64/ld-linux-x86-64.so.2 (0x00007fbac5058000) libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fbac405e000) libattr.so.1 => /lib64/libattr.so.1 (0x00007fbac3e59000) [[email protected] ~]# for i in `ldd /bin/ls|grep -o ‘/[[:alnum:]/.-]\+‘|cut -d/ -f3`;do cp /lib64/$i /mnt/sysroot/lib64/;done cp:是否覆盖"/mnt/sysroot/lib64/libc.so.6"? y cp:是否覆盖"/mnt/sysroot/lib64/libdl.so.2"? y cp:是否覆盖"/mnt/sysroot/lib64/ld-linux-x86-64.so.2"? y [[email protected] ~]# ls /mnt/sysroot/lib64 ld-linux-x86-64.so.2 libcap.so.2 libpthread.so.0 libtinfo.so.5 libacl.so.1 libc.so.6 librt.so.1 libattr.so.1 libdl.so.2 libselinux.so.1 [[email protected] ~]# chroot /mnt/sysroot bash-4.1# ls bin dev home lib64 mnt sbin usr boot etc lib lost+found proc sys var
boot + rootfs都完成了,然后新建虚拟机(目标机),使用此硬盘当作启动盘启动(宿主机(也是虚拟机)要关闭,一个硬盘不能同时被2个虚拟机使用)
目标机启动后的界面:
进入系统后的界面:
二、linux的内核模块
lcpci 查看PCI设备的命令
lsmod 查看当前系统加载的模块
modinfo MOD_NAME 查看某模块的详细信息
动态装载某模块:
modprobe MOD_NAME
insmod /path/to/module_file #insmod安装模块,需要指定模块文件的路径
动态卸载某模块:
modprobe -r MOD_NAME
rmmod MOD_NAME
[[email protected] ~]# ls /lib alsa cpp firmware kbd lsb modules security terminfo udev [[email protected] ~]# cd /lib/modules/ [[email protected] modules]# ls 2.6.32-431.el6.x86_64 [[email protected] modules]# cd 2.6.32-431.el6.x86_64/ [[email protected] 2.6.32-431.el6.x86_64]# ls build modules.dep.bin modules.pcimap extra modules.drm modules.seriomap kernel modules.ieee1394map modules.symbols misc modules.inputmap modules.symbols.bin modules.alias modules.isapnpmap modules.usbmap modules.alias.bin modules.modesetting source modules.block modules.networking updates modules.ccwmap modules.ofmap vdso modules.dep modules.order weak-updates
modules.alias:模块别名的列表
modules.dep.bin:模块间的依赖关系,是使用depmod命令生成的
[[email protected] 2.6.32-431.el6.x86_64]# ls kernel/ arch crypto drivers fs kernel lib mm net sound
arch:硬件平台架构
crypto:常用的加密算法
drivers:硬件驱动
fs:文件系统
通过上面的命令学习就可以把宿主机上的模块文件也复制到目标机上,增加目标机的功能
例如:复制宿主机上的e1000网卡驱动模块到目标机上,实现目标机的联网功能
#宿主机上为目标机添加e1000的驱动模块,ping,ifconfig,insmode,rmmode,modprobe命令 [[email protected] ~]# mkdir -v /mnt/sysroot/lib/modules mkdir: created directory `/mnt/sysroot/lib/modules‘ [[email protected] ~]# cp /lib/modules/2.6.32-431.el6.x86_64/kernel/drivers/net/e1000/e1000.ko /mnt/sysroot/lib/modules [[email protected] ~]# ls /mnt/sysroot/lib/modules e1000.ko [[email protected] ~]# ldd /sbin/ifconfig linux-vdso.so.1 => (0x00007fff123d9000) libselinux.so.1 => /lib64/libselinux.so.1 (0x0000003da1200000) libc.so.6 => /lib64/libc.so.6 (0x0000003d9fa00000) libdl.so.2 => /lib64/libdl.so.2 (0x0000003d9f600000) /lib64/ld-linux-x86-64.so.2 (0x0000003d9f200000) [[email protected] ~]# cp /sbin/ifconfig /mnt/sysroot/sbin/ [[email protected] ~]# ls /mnt/sysroot/sbin/ ifconfig [[email protected] ~]# ls /mnt/sysroot/lib64 #ifconfig命令所需的库文件都有 ld-linux-x86-64.so.2 libcap.so.2 libpthread.so.0 libtinfo.so.5 libacl.so.1 libc.so.6 librt.so.1 libattr.so.1 libdl.so.2 libselinux.so.1 [[email protected] ~]# ldd /bin/ping linux-vdso.so.1 => (0x00007fff9f5ff000) libidn.so.11 => /lib64/libidn.so.11 (0x00007f3d275b5000) libc.so.6 => /lib64/libc.so.6 (0x00007f3d27221000) /lib64/ld-linux-x86-64.so.2 (0x0000003d9f200000) [[email protected] ~]# ls /mnt/sysroot/lib64 ld-linux-x86-64.so.2 libcap.so.2 libpthread.so.0 libtinfo.so.5 libacl.so.1 libc.so.6 librt.so.1 libattr.so.1 libdl.so.2 libselinux.so.1 [[email protected] ~]# cp /lib64/libidn.so.11 /mnt/sysroot/lib64 [[email protected] ~]# cp /bin/ping /mnt/sysroot/bin/ [[email protected] ~]# cp /sbin/{insmod,rmmod,modprobe} /mnt/sysroot/sbin [[email protected] ~]# ls /mnt/sysroot/sbin ifconfig insmod modprobe rmmod
启动目标机:
可以看到没装载网卡驱动的时候eth0是没有显示的
modeprobe装载模块只需指定模块名,不需要指定模块文件的路径但需要环境支持,所以这里我们使用insmod命令装载网卡驱动模块。
以上是关于linux基础21定制linux系统的主要内容,如果未能解决你的问题,请参考以下文章
Android 逆向Linux 文件权限 ( Linux 权限简介 | 系统权限 | 用户权限 | 匿名用户权限 | 读 | 写 | 执行 | 更改组 | 更改用户 | 粘滞 )(代码片段
2018-04-26 《鸟哥的Linux私房菜 基础学习篇(第四版)》 第21章 软件安装_原始码与Tarball 笔记