查看本机硬件设备信息:常见的几个命令
1、cat /proc/cpuinfo 查看cpu核心的信息
2、lsusb 查看USB设备信息
3、lspci 查看pci设备信息
4、hal-device 查看所有硬件设备的详细信息
Linux系统裁剪笔记之四busybox
1.什么裁剪?
本篇文章的主要目的是让笔者和读者更深的认识Linux系统的运作方式,大致内容就是把Linux拆开自己一个个组件来组装,然后完成一个微型的Linux系统.下面,让我们来实现吧..写的不好的地方请指教.
2.原理
大家都知道,操作系统的启动流程是(主要是Linux):POST—>BIOS—>MBR—kernel-->initrd-->sbin/init,
POST,BIOS都不是我们管的,所以这里我们从MBR开始,Linux的系统引导先主要是用的grub这个软件,grub引导系统了,然后启动内核,内核调用initrd来实现最基本的操作系统.
3.实验 (所有操作均在虚拟机宿主机为redhat 5.4上实现,且定义硬盘时选IDE)
Kernel + initrd(busybox制作,提供ext3文件系统模块) + ROOTFS (busybox制作)
硬件驱动:initrd
initrd: 仅需要提供内核访问真正的根文件系统所在设备需要的驱动
存储设备和文件系统相关的模块
系统初始化rc.sysinit: 初始其它硬件的驱动程序;
ROOTFS: busybox,init不支持运行级别
/etc/inittab:格式也不尽相同 ash,hush bash
如何编译busybox:
编译前准备
busybox下载: (下载地址:https://busybox.net/)
下载busybox:busybox-1.20.2.tar.bz2
kernel下载:linux-2.6.38.tar.bz2
准备一个IDE硬盘分成2个分区
IDE:
/dev/hda1: ext3 /boot
/dev/hda2: ext3 /
在宿主虚拟机添加IDE硬盘,并分2个分区,并挂载:
mount /dev/hda1 /mnt/boot
mount /dev/hda2 /mnt/sysroot
步骤如下:
[root@localhost ~]# ls
anaconda-ks.cfg Desktop etc install.log lib sbin sysrootv bin
busybox-1.20.2.tar.bz2 dev init install.log.syslog proc sys testiso
[root@localhost ~]# tar -xvf busybox-1.20.2.tar.bz2
[root@localhost ~]# cd busybox-1.20.2
[root@localhost busybox-1.20.2]# make menuconfig 此命令驱动图形编译界面如下步骤:
敲回车进入
选择第一选项
其他选项可以保持默认不修改,保存退出
先把内核文件下载好后解压 linux-2.6.38.tar.bz2 并复制里面的linux-2.6.38/include/mtd/ubi-user.h,否则编译安装busybox会报错误。
[root@localhost ~]# tar xf linux-2.6.38.tar.bz2 -C /usr/src #解压内核文件到指定目录/usr/src
[root@localhost ~]#ls /usr/src
kernels linux-2.6.38 redhat
[root@localhost ~]# ls /usr/src/linux-2.6.38/include/mtd
inftl-user.h Kbuild mtd-abi.h mtd-user.h nftl-user.h ubi-user.h
[root@localhost ~]# cd /root/busybox-1.20.2
[root@localhost busybox-1.20.2]# ls
applets configs editors libbb Makefile.custom printutils shell
applets_sh console-tools examples libpwdgrp Makefile.flags procps sysklogd arch coreutils findutils LICENSE Makefile.help README testsuite archival debianutils include loginutils miscutils runit TODOAUTHORS docs init mailutils modutils scripts TODO_unicode Config.in e2fsprogs INSTALL Makefile networking selinux util-linux
[root@localhost busybox-1.20.2]# cd include/
[root@localhost include]# ls
applet_metadata.h autoconf.h dump.h libbb.h rtc_.h usage.src.h
applets.h bb_archive.h fix_u32.h liblzo_interface.h shadow_.h volume_id.h
applets.src.h bb_e2fs_defs.h grp_.h platform.h unicode.h xatonum.h
ar.h busybox.h inet_common.h pwd_.h usage.h xregex.h
[root@localhost include]# mkdir mtd
[root@localhost include]# cp /usr/src/linux-2.6.38/include/mtd/ubi-user.h mtd/
[root@localhost include]# ls
applet_metadata.h bb_archive.h dump.h mtd unicode.h xregex.h
applets.h bbconfigopts_bz2.h fix_u32.h NUM_APPLETS.h usage_compressed.h
applets.src.h bbconfigopts.h grp_.h platform.h usage.h
applet_tables.h bb_e2fs_defs.h inet_common.h pwd_.h usage.src.h ar.h busybox.h libbb.h rtc_.h volume_id.h
autoconf.h config liblzo_interface.h shadow_.h xatonum.h
[root@localhost include]# ls mtd
ubi-user.h
[root@localhost include]# pwd
/root/busybox-1.20.2/include
[root@localhost include]# cd ..
[root@localhost busybox-1.20.2]# ls
applets configs editors libbb Makefile.custom printutils shell
applets_sh console-tools examples libpwdgrp Makefile.flags procps sysklogd arch coreutils findutils LICENSE Makefile.help README testsuite archival debianutils include loginutils miscutils runit TODO AUTHORS docs init mailutils modutils scripts TODO_unicode Config.in e2fsprogs INSTALL Makefile
networking selinux util-linux
[root@localhost busybox-1.20.2]# pwd
/root/busybox-1.20.2
[root@JackTest busybox-1.20.2]# make install #编译成功后生成_install文件
./_install//usr/sbin/ubiupdatevol -> ../../bin/busybox
./_install//usr/sbin/udhcpd -> ../../bin/busybox
--------------------------------------------------
You will probably need to make your busybox binary
setuid root to ensure all configured applets will
work properly.
--------------------------------------------------
[root@localhost busybox-1.20.2]# ls
applets busybox_unstripped.map e2fsprogs libbb Makefile.help scripts
applets_sh busybox_unstripped.out editors libpwdgrp miscutils selinux arch Config.in examples LICENSE modutils shell archival configs findutils loginutils networking sysklogd AUTHORS console-tools include mailutils printutils testsuite
busybox coreutils init Makefile procps TODO util-linux
busybox.links debianutils _install Makefile.custom README TODO_unicode busybox_unstripped docs INSTALL Makefile.flags runit
[root@localhost busybox-1.20.2]# ll _install #查看_install文件信息
total 28
drwxr-xr-x 2 root root 4096 2016-11-29 13:50 bin
lrwxrwxrwx 1 root root 11 2016-11-29 13:50 linuxrc -> bin/busybox
drwxr-xr-x 2 root root 4096 2016-11-29 13:51 sbin
drwxr-xr-x 4 root root 4096 2016-11-29 13:51 usr
[root@localhost busybox-1.20.2]# du -sh _install
3.0M _install #initrd,fsfiles
[root@localhost busybox-1.20.2]# cp _install /tmp/busybox -a #一份用于initrd
[root@localhost busybox-1.20.2]# cp _install /tmp/busybox2 -a #一份用于rootfs
[root@localhost busybox-1.20.2]# cd /tmp/busybox
[root@localhost busybox]# ll
total 28
drwxr-xr-x 2 root root 4096 2016-11-29 13:50 bin
lrwxrwxrwx 1 root root 11 2016-11-29 13:58 linuxrc -> bin/busybox
drwxr-xr-x 2 root root 4096 2016-11-29 13:51 sbin
drwxr-xr-x 4 root root 4096 2016-11-29 13:51 usr
[root@JackTest busybox]# rm linuxrc
rm: remove symbolic link `linuxrc'? y
[root@localhost busybox]# mkdir proc sys etc dev tmp mnt/sysroot lib/modules sysroot -pv
[root@localhost busybox]# modinfo ext3 #复制ext3依赖的模块
filename: /lib/modules/2.6.23.1-42.fc8/kernel/fs/ext3/ext3.ko
...
depends: jbd
[root@localhost busybox]# modinfo jbd
filename: /lib/modules/2.6.23.1-42.fc8/kernel/fs/jbd/jbd.ko
[root@localhost busybox]# cp /lib/modules/2.6.23.1-42.fc8/kernel/fs/ext3/ext3.ko lib/modules/
[root@localhost busybox]# cp /lib/modules/2.6.23.1-42.fc8/kernel/fs/jbd/jbd.ko lib/modules/
[root@localhost busybox]# vim init
#!/bin/sh
mount -t proc proc /proc
mount -t sysfs sysfs /sys
mdev -s
insmod /lib/modules/jbd.ko
insmod /lib/modules/ext3.ko
mount -t ext3 /dev/hda2 /mnt/sysroot
exec switch_root /mnt/sysroot /sbin/init #将/mnt/sysroot根权限转交给/sbin/init
[root@localhost busybox]# chmod +x init
[root@localhost busybox]# ls
bin dev etc init lib proc sbin sys sysroot usr
[root@localhost busybox]# mkdir mnt/sysroot -pv
mkdir: 已创建目录 “mnt”
mkdir: 已创建目录 “mnt/sysroot”
[root@localhost busybox]# ls
bin dev etc init lib mnt proc sbin sys sysroot usr
[root@localhost busybox]# rm -rf sysroot
[root@localhost busybox]# ls
bin dev etc init lib mnt proc sbin sys usr
[root@localhost busybox]# mknod dev/console c 5 1 #新增console模块
[root@localhost busybox]# mknod dev/null c 1 3 #新增null模块
[root@localhost busybox]# tree dev
dev
|-- console
`-- nullmdev -s
[root@localhost busybox]# mkdir tmp
[root@localhost busybox]# ls
bin dev etc init lib mnt proc sbin sysroot tmp usr
[root@localhost busybox]# find . |cpio -H newc --quiet -o |gzip -9 > /mnt/boot/initrd.gz
[root@localhost busybox]# ls -lh /mnt/boot/initrd.gz
-rw-r--r-- 1 root root 1.2M 12-15 08:55 /mnt/boot/initrd.gz
[root@localhost busybox]# cp /boot/vmlinuz-2.6.18-164.el5 /mnt/boot/vmlinuz #复制内核
[root@localhost busybox]# ls -lh /mnt/boot
总计 3.1M
-rw-r--r-- 1 root root 1.2M 12-15 08:55 initrd.gz
drwx------ 2 root root 12K 12-15 08:53 lost+found
-rw-r--r-- 1 root root 1.9M 12-15 08:57 vmlinuz
[root@localhost busybox]# grub-install --root-directory=/mnt /dev/hda #安装grub
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/hda #此系统创建所需的引导程序
(hd1)/dev/sda
[root@localhost busybox]# ls /mnt/boot
grub initrd.gz lost+found vmlinuz
[root@localhost busybox]# vi /mnt/boot/grub/grub.conf
default=0
timeout=5
title John MiniLinux(2.6.18)
root(hd0,0)
kernel /vmlinuz ro root=/dev/hda2
initrd /initrd.gz
[root@localhost busybox]# ls /mnt/boot
grub initrd.gz lost+found vmlinuz
二、系统初始化rc.sysinit: 初始其它硬件的驱动程序
[root@localhost busybox]# cd
[root@localhost ~]# cd busybox-1.20.2 切换到busybox的解压缩目录
[root@localhost busybox-1.20.2]# ls
applets busybox_unstripped.map e2fsprogs libbb Makefile.help scripts applets_sh busybox_unstripped.out editors libpwdgrp miscutils selinux
arch Config.in examples LICENSE modutils shell
archival configs findutils loginutils networking sysklogd
AUTHORS console-tools include mailutils printutils testsuite
busybox coreutils init Makefile procps TODO util-linux
busybox.links debianutils _install Makefile.custom README TODO_unicode busybox_unstripped docs INSTALL Makefile.flags runit
[root@localhost busybox-1.20.2]# cp _install/* /mnt/sysroot/ -a
[root@localhost busybox-1.20.2]# cd /mnt/sysroot/
[root@localhost sysroot]# ls
bin linuxrc lost+found sbin usr
[root@localhost sysroot]# rm linuxrc
rm:是否删除 符号链接 “linuxrc”? y
[root@localhost sysroot]# ls
bin lost+found sbin usr
[root@localhost sysroot]# mkdir proc sys dev tmp var/{log,lock,run} lib/modules etc/rc.d/init.d root boot mnt media -pv #创建所需目录
[root@localhost sysroot]# ls
bin boot dev etc lib lost+found media mnt proc root sbin sys tmp usr var
[root@localhost sysroot]# ls sbin/
acpid fbsplash hdparm klogd mkdosfs nameif setconsole syslogd adjtimex fdisk hwclock loadkmap mke2fs pivot_root slattach tunctl arp findfs ifconfig logread mkfs.ext2 poweroff start-stop-daemon udhcpc blkid freeramdisk ifdown losetup mkfs.minix raidautorun sulogin vconfig blockdev fsck ifenslave lsmod mkfs.vfat reboot swapoff watchdog bootchartd fsck.minix ifup makedevs mkswap rmmod swapon zcip depmod getty init man modinfo route switch_root devmem halt insmod mdev modprobe runlevel sysctl
[root@localhost sysroot]# vim etc/inittab
::sysinit:/etc/rc.d/rc.sysinit
console::respawn:-/bin/sh
::ctrlaltdel:/sbin/reboot
::shutdown:/bin/umount -a -r
[root@test busybox2]# vim etc/fstab
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
/dev/hda1 /boot ext3 defaults 0 0
/dev/hda2 / ext3 defaults 1 1
[root@localhost sysroot]# sync 把内容同步至硬盘中以防丢失
[root@localhost sysroot]# mknod dev/console c 5 1 #新增console模块
[root@localhost sysroot]# mknod dev/null c 1 3 #新增null模块
[root@localhost sysroot]# ll dev/
total 0
crw-r--r-- 1 root root 5, 1 Nov 29 15:42 console
crw-r--r-- 1 root root 1, 3 Nov 29 15:42 null
[root@localhost sysroot]# vim etc/rc.d/rc.sysinit
#!/bin/sh
#
echo -e "\tWelcome to \033[34mJohn Mini \033[0m Liniux"
echo -e "Remounting the root filesystem .................[ \033[32mOK\033[0m ]"
mount -t proc proc /proc
mount -t sysfs sysfs /sys
mount -o remount,rw /
echo -e "Creating the files of device ...................[ \033[32mOK\033[0m ]"
mdev -s
echo -e "Mounting the filesystem .......................[ \033[32mOK\033[0m ]"
mount -a
swapon -a
[root@localhost sysroot]# chmod +x etc/rc.d/rc.sysinit
[root@localhost sysroot]# sync #同步至硬盘中
[root@localhost sysroot]# sync
[root@localhost sysroot]# sync
至此一个精简版的linux系统就完成了
-----------------------------------------------------------------------------------
下面是通过脚本添加命令及模块用来完善系统功能的:
[root@localhost busybox]# ls /mnt/sysroot/
bin boot dev etc lib lost+found media mnt root sbin sys tmp usr var
[root@localhost sysroot]# du -sh
4.0M
[root@localhost boot]# du -sh
2.9M
[root@localhost ~]# ./cpbin.sh #cpbin脚本在文章最下面有附带脚本
Your command: bash
执行过cpbin脚本复制过bash命令后需更改配置文档/mnt/sysroot/etc/inittab,把/bin/sh改为/bin/bash
或者将/mnt/sysroot/bin目录下面的的sh先删除掉,再把/mnt/sysroot/bin/bash链接为当前目录下的sh
两种方法都可以,但是建议用第一种修改配置文档的方式,不建议删除链接后再重新链接。
[root@localhost bin]# rm sh 先删除/mnt/sysroot/bin目录下的软链接sh
rm:是否删除 符号链接 “sh”? y
[root@localhost bin]# ln -sv bash sh 重新建立一个sh软链接指向当前目录的bash
创建指向“bash”的符号链接“sh”
[root@localhost bin]# ll
总计 3172
-rwxr-xr-x 1 root root 801512 12-16 09:08 bash
-rwxr-xr-x 1 root root 2025496 12-15 13:43 busyboxx
lrwxrwxrwx 1 root root 4 12-16 13:56 sh -> bash
-----------------------------------------------------------------------------------
增加网络功能
[root@localhost ~]# modinfo mii 查看网卡模块需要的lib文档
filename: /lib/modules/2.6.18-164.el5/kernel/drivers/net/mii.ko
license: GPL
description: MII hardware support library
author: Jeff Garzik <jgarzik@pobox.com>
srcversion: 16DCEDEE4B5629C222C352D
depends:
vermagic: 2.6.18-164.el5 SMP mod_unload gcc-4.1
[root@localhost ~]# modinfo pcnet32 查看网卡模块需要的lib文档
filename: /lib/modules/2.6.18-164.el5/kernel/drivers/net/pcnet32.ko
license: GPL
description: Driver for PCnet32 and PCnetPCI based ethercards
author: Thomas Bogendoerfer
[root@localhost ~]# cp /lib/modules/2.6.18-164.el5/kernel/drivers/net/mii.ko /mnt/sysroot/lib/modules/
[root@localhost ~]# cp /lib/modules/2.6.18-164.el5/kernel/drivers/net/pcnet32.ko /mnt/sysroot/lib/modules/
[root@localhost ~]# ls /mnt/sysroot/lib
modules
[root@localhost ~]# ls /mnt/sysroot/lib/modules/
mii.ko pcnet32.ko
#[root@test sysroot]# modinfo e1000 #新增启动网络模块,请确认网卡型号
#[root@test sysroot]#cp /lib/modules/2.6.18-164.el5PAE/kernel/drivers/net/e1000/e1000.ko lib/modules
[root@test sysroot]# vim /mnt/sysroot/etc/rc.d/init.d/network (参考:Linux系统裁剪笔记之二insmod)
[root@test sysroot]# vim etc/rc.d/rc.sysinit
... #新增以下内容
echo "Initalizing network device ..."
/sbin/insmod /lib/modules/e1000.ko
[ $? -eq 0 ] && success "Initializing network device" || failure "Initializing network device"
ifconfig lo 127.0.0.1/8
[ $? -eq 0 ] && success "Activating loopb
ack network" || failure "Activating loopback network"
ifconfig eth0 10.119.131.208/22 up
[ $? -eq 0 ] && success "Activating eth0 network" || failure "Activating eth0 network"
4、在系统登录时提供banner信息
# vi /mnt/sysroot/etc/issue
Welcome to Jack Linux XXXXX62 ...
Kernel \r
5、在系统登录时显示用户信息
[root@test sysconfig]# cat /mnt/sysroot/etc/sysconfig/network
HOSTNAME=Jack.test.com
[root@test etc]# vim rc.d/rc.sysinit
... #新增以下内容
echo "Set the hostname..."
[ -f /etc/sysconfig/network ] && . /etc/sysconfig/network
[ -z $HOSTNAME -o "HOSTNAME" == '(none)' ] && HOSTNAME=localhost
/bin/hostname $HOSTNAME
[ $? -eq 0 ] && success "Set the hostname" || failure "Set the hostname"
6、在系统登录时提供日志功能
[root@test sysroot]# vim etc/rc.d/rc.sysinit
... #新增以下内容
echo "Strat syslog..."
syslogd
[ $? -eq 0 ] && success "Start syslog" || failure "Start syslog"
klogd
[ $? -eq 0 ] && success "Start klog" || failure "Start klog"
[root@test sysroot]# cat etc/syslog.conf
*.info;auth.none /var/log/messages
auth.* /var/log/secure
[root@test sysroot]# ll var/log #新建以下两个文件,且改为600权限
total 48
-rw------- 1 root root 47913 Dec 5 15:46 messages
-rw------- 1 root root 0 Dec 5 15:50 secure
7、在系统登录时提供SSH功能
[root@test sysroot]# cat etc/shells
/bin/sh
/bin/bash
/bin/hush
/bin/ash
[root@test sysroot]# vim etc/fstab
[root@test sysroot]# cat etc/fstab
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
devpts /dev/pts devpts mode=620 0 0
/dev/hda1 /boot ext3 defaults 0 0
/dev/hda2 / ext3 defaults 1 1
[root@test sysroot]# ls
bin boot dev etc lib lost+found media mnt proc root sbin sys tmp usr var
[root@test sysroot]# mkdir dev/pts
[root@test sysroot]# cat etc/shells
/bin/sh
/bin/bash
/bin/hush
/bin/ash
[root@test sysroot]# cat etc/fstab
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
devpts /dev/pts devpts mode=620 0 0
/dev/hda1 /boot ext3 defaults 0 0
/dev/hda2 / ext3 defaults 1 1
[root@test sysroot]# mkdir etc/dropbear
[root@test sysroot]# dropbearkey -t rsa -f /mnt/sysroot/etc/dropbear/dropbear_rsa_host_key -s 2048
Will output 2048 bit rsa secret key to '/mnt/sysroot/etc/dropbear/dropbear_rsa_host_key'
Generating key, this may take a while...
Public key portion is:
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAnGoBr5U1wMb0bsNmBC5PsX+e0tTc9j+UY/T/9cG2SrBbUcLZ/+vlHFmmrxMr3N/hJZBEFHwDoOxffnx6v7GhVFXlcWhNajq7DuSdLqCmknKAd/BzYU/61iQKTqGECLW7cg0sF30NE65cquumEfctUVbIhZ4m33B6NqBBIRUz/3pujbsmOoIAXnpIyVMKpQOHcDEER9dLC2JzBJ5iM2ZE7eaSW/Ddw3SYB3UrbE43A1xHZbXPpVSbr9GQS3r6DvgwFesUd1PPCLl8+5vq2EkCwWd3wiJkzhcI0TALyNaZnftPr3qQ2Bq3XEPnYMeA85ZRe65JRvSAoGqLy7XcPvSrLLLRw== root@test
Fingerprint: md5 3c:04:cf:fd:8c:89:a5:a8:3e:a8:90:bc:22:56:91:1e
[root@test sysroot]# dropbearkey -t dss -f /mnt/sysroot/etc/dropbear/dropbear_dss_host_key
Will output 1024 bit dss secret key to '/mnt/sysroot/etc/dropbear/dropbear_dss_host_key'
Generating key, this may take a while...
Public key portion is:
ssh-dss AAAAB3NzaC1kc3MAAACBANqb58a9g4TENxtXPl4hjM2Gkgp+GHcDn8DYQRJQDdQLr0GwwoA3xJWrB1geAFUem9vDcpQ5/oa0tEr300IyXUhTaldGj9C5yqQXPsCoJZOLBr5FZCpbBJ9D7xljAVLMXJhL4yB4hDbR+U1keP9eHe2PuuamD7VN8obAfG0MP25XAAAAFQD/eG5E3tlk6wG7NXmGqKNrFTgbMwAAAIEAjBh2Omy+VwqMSp7K0X2LkzN95VYPK7HpWIzeVPscdKzU4USr+Z2axmYlztzk+BaFkdhh3GO8FitUNjLsjIoOoPtPBZ1u0mc3tetnoTtjjJTaRrXstnaW4tR0844PGYo8+CCMnN6tmVUTxefNuo68FhRVp14kjcS73nENm7prqtEAAACBAMfr2mi48f36s+Dl0g+o0TefmV5GpP7W4wEV3yXzN/2loJS8Sp1yL4JbdMykpJQeOc5vl/GWRveV1tuudW2wI30O22Srpb6KZaV8BnMRthJtfUo8IEOctu4dqZTazoIP02tHiUTps1nBxH1VF2ZI0Veun0oP9/FWEEgVbHsoLl5r root@test
Fingerprint: md5 bf:81:55:ea:64:b3:8d:80:b7:42:3a:2c:f0:0d:68:bc
[root@test sysroot]# ls etc/dropbear/
dropbear_dss_host_key dropbear_rsa_host_key
[root@test sysroot]# mkdir usr/lib
[root@test sysroot]# cp -d /lib/libnss_files* /mnt/sysroot/lib/
[root@test sysroot]# cp -d /usr/lib/libnss3.so /usr/lib/libnss_files.so /mnt/sysroot/usr/lib/
[root@test sysroot]# cp /etc/nsswitch.conf ./etc/
[root@test sysroot]# ll usr/lib/
total 1242
-rwxr-xr-x 1 root root 1188804 Dec 6 10:23 libnss3.so
lrwxrwxrwx 1 root root 27 Dec 6 10:23 libnss_files.so -> ../../lib/libnss_files.so.2
-rwxr-xr-x 1 root root 75284 Dec 6 10:39 libz.so.1
[root@test sysroot]# ll lib/
total 1848
-rwxr-xr-x 1 root root 125736 Nov 30 15:11 ld-linux.so.2
-rwxr-xr-x 1 root root 45288 Dec 6 10:39 libcrypt.so.1
-rwxr-xr-x 1 root root 1611564 Nov 30 15:11 libc.so.6
-rwxr-xr-x 1 root root 16428 Nov 30 15:11 libdl.so.2
-rwxr-xr-x 1 root root 46680 Dec 6 10:22 libnss_files-2.5.so
lrwxrwxrwx 1 root root 19 Dec 6 10:22 libnss_files.so.2 -> libnss_files-2.5.so
-rwxr-xr-x 1 root root 13276 Nov 30 15:11 libtermcap.so.2
-rwxr-xr-x 1 root root 15164 Dec 6 10:39 libutil.so.1
drwxr-xr-x 2 root root 1024 Nov 30 16:29 modules
[root@test sysroot]# cat etc/nsswitch.conf
passwd: files
shadow: files
group: files
hosts: files dns
[root@test sysroot]# sync
以下为启动监听出错时解决办法:
[root@test sysroot]# vi /etc/rc.d/rc.sysinit
... #新增以下内容
echo "Activating SSH Service ..."
/sbin/dropbear
[ $? -eq 0 ] && success "Activated SSH service" || failure "Activated SSH service"
[root@fox ~]# netstat -lntp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 522/dropbear
[root@test sysroot]# /bin/dbclient -l root 110.119.131.204 #进入该主机后远程连接其它PC
【附带cpbin命令复制脚本】
附1:自动复制相关库文件
* FILE=/usr/local/src
TEST=${FILE#*/}:$TEST结果为usr/local/src, 以/为关键字,删除从左边数第一个/及关键字/左边的所有字符串。
DEST=${FILE##*/}:$DEST结果为src,以/为关键字,删除最后一个关键字/及关键字/左边的所有字符串。
DOTEST=${FILE%/*}:$DOTEST结果为/usr/local,以/为关键字,删除从右边数第一个/及关键字/右边的所有字符串。
DODEST=${FILE%%/*}:$DODEST结果为空,以/为关键字,删除从右边数最后一个/及关键字/右边的所有字符串。
[root@localhost ~]# vim cpbin.sh
#!/bin/bash
# bincopy.sh
DEST=/mnt/sysroot
libcp() { #该函数接收一个库文件路径
LIBPATH=${1%/*} #红色部分将/lib/libc.so.6切割成/lib/ %:表示从右边数删除第一个/及其右边的字符串。
[ ! -d $DEST$LIBPATH ] && mkdir -p $DEST$LIBPATH #路径是否存在
[ ! -e $DEST${1} ] && cp $1 $DEST$LIBPATH && echo "copy lib $1 finished."#库文件是否存在
}
bincp() { #该函数接收一个命令对应的地址,如:/bin/ls
CMDPATH=${1%/*} #红色部分将/bin/ls切割成/bin/
[ ! -d $DEST$CMDPATH ] && mkdir -p $DEST$CMDPATH
[ ! -e $DEST${1} ] && cp $1 $DEST$CMDPATH
for LIB in `ldd $1 | grep -o "/.*lib\(64\)\{0,1\}/[^[:space:]]\{1,\}"`; do
libcp $LIB # /.*lib绿色为:/开始,中间任意字符,接着lib
done # \(64\)\{0,1\}红色为:64出现0或1次
} # [^[:space:]]\{1,\}绿色为:空格开关且至少出现一次
read -p "Your command: " CMD
until [ $CMD == 'q' ]; do
! which $CMD &> /dev/null && echo "Wrong command" && read -p "Input again:" CMD && continue
COMMAND=`which $CMD |grep -v "^alias" |grep -o "[^[:space:]]\{1,\}"`#以alias开头的行不显示
bincp $COMMAND
echo"copy $COMMAND finished."
read -p"Continue: " CMD
done