Linux系统裁剪和定制 裁剪linux内核
liebian365 2024-11-11 14:50 20 浏览 0 评论
1 参考网页
1.1 https://www.cnblogs.com/sysk/p/4983638.html
1.2 https://blog.csdn.net/kingolie/article/details/53428541
1.3 http://mgalgs.github.io/2015/05/16/how-to-build-a-custom-linux-kernel-for-qemu-2015-edition.html
1.4 https://github.com/ir193/tiny_linux/blob/master/NOTE.md
[注]参考1.1中步骤,会碰到很多bug,一路走来快放弃了。(VMware Workstation)
参考1.2中步骤,能完成系统裁剪,但系统中没有什么有意义的功能。(VMware Workstation)
参考1.3和1.4,可完成qemu模拟器下的系统裁剪。
本文踩坑之后,完成的系统磁盘文件大小不到80MB,可支持nginx和ssh。(运行环境是Vmware Workstation14 Pro)
操作系统运行情况:
SSH客户端访问:
HTTP浏览器访问页面:
2 资源下载
2.1 操作系统内核kernel:linux-3.12.26
https://download.csdn.net/download/shenlongqing/12387854
2.2 busybox:busybox-1.22.1
https://download.csdn.net/download/shenlongqing/12387864
2.3 dropbear:dropbear-2014.65
https://download.csdn.net/download/shenlongqing/12387847
2.4 nginx:nginx-1.4.5
https://download.csdn.net/download/shenlongqing/12387856
3 工具准备
3.1 VMware Workstation
产品:VMware Workstation 14 Pro
版本:14.1.3 build-9474260
3.2 MobaXterm
产品:免费的SSH客户端工具
版本:Personal Edition v11.1 Build 3860
3.3 CenterOS 6.5 64位
版本号:Linux hostname.localhost 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux
4 移植步骤
[注]启动流程参考:
linux系统启动流程
POST-->BIOS(BOOT Sequence)-->MBR(bootloader,446个字节)-->kernel-->initrd(initramfs)-->(ROORFS)/sbin/init(/etc/inittab)
以上linux启动流程只是针对于centos6系列基于upstart流程的2.6内核,centos7使用了stytemd和此稍有不同。
可参考网页:https://www.cnblogs.com/sysk/p/4778976.html
4.1 在VMware Workstation中安装CenterOS6.5 64位
版本号:Linux hostname.localhost 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux
4.2 准备硬盘
为虚拟机准备一块1G容量(大小也可自定)硬盘,并为硬盘分区。磁盘文件:C:\VirtualMachines\CentOS64\CentOS64_Portable.vmdk (路径和名字可自定)
(1)为硬盘分区,在我的虚拟机中新加的硬盘为/dev/sdb,将此硬盘分区,其中/dev/sdb1=50M, 剩余的容量全部给 /dev/sdb2,分区操作命令:
echo -e "n \n p \n 1 \n \n +50M \n n \n p \n 2 \n \n \n w \n" | fdisk /dev/sdb
(2)将分区格式化,格式化操作命令:
mke2fs -t ext2 /dev/sdb1
mke2fs -t ext2 /dev/sdb2
(3)挂载磁盘并安装grub引导程序:
mkdir /mnt/boot
mount /dev/sdb1 /mnt/boot
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
4.3 编译内核,添加到硬盘中
(1)安装必要的工具和依赖包:
yum install ncurses-devel
[注]必要的工具:perl、bc、gcc
若有必要:
yum groupinstall "Development Libraries" " Development Tools"
(2)下载并解压源码包,操作命令:
cp linux-3.12.26.tar.xz /usr/src
xz -d linux-3.12.26.tar.xz
tar -xvf linux-3.12.26.tar
ln -sv /usr/src/linux-3.12.26/ /usr/src/linux
make allnoconfig
make menuconfig
(3)进行内核编译配置:
I)首页:
II)进入 General setup 选项
III)返回首页,进入Processor type and features
IV)进入 Processor family (Generic-x86-64) 选择 cpu 类型 默认即可
V)返回首页,进入 Bus options (PCI etc.)
VI)返回首页,返回首界面进入 Executable file formats / Emulations
VII)返回首页,进入Networking support--->Networking options
VIII)返回首页,进入 Device Drivers --->Generic Driver Options
IX)返回上级页面
X)进入SCSI device support
XI)进入SCSI low-level dirvers --->
XII)返回上级页面,进入 Network device support---> Ethernet driver support (NEW)
XIII)返回到 Network device support 页面,选择 Input device support
XIV)返回上级添加 usb 支持 USB support
XV)返回首页 File systems
XVI)退出保存配置
(4)编译并存入硬盘,操作命令:
make
make bzImage
cp ./arch/x86/boot/bzImage /mnt/boot
4.4 添加 rootfs 及二进制程序(由 busybox 提供)
(1)下载解压源码包,操作命令:
tar -xf busybox-1.22.1.tar.bz2 -C /usr/src/
cd /usr/src/busybox-1.22.1/
make menuconfig
(2)进行busybox编译配置:
进入 Busybox Settings ---->Build Options
此处需要选择 :
Busybox Settings --> Build Options --> Build BusyBox as a static binary (no shared libs)
(3)安装glibc静态支持,操作命令:
yum install glibc-static
(4)编译并存入硬盘,操作命令:
make
make install
mount /dev/sdb2 /mnt/sysroot/
cp -a ./_install/* /mnt/sysroot/
mkdir -pv /mnt/sysroot/{etc,boot,root,mnt,media,proc,sys,dev,home,lib,lib64,var,tmp}
[注] 由于 busybox 启动时默认的 init 程序为 /etc/init.d/rcS
mkdir -pv /mnt/sysroot/etc/init.d
vim /mnt/sysroot/etc/init.d/rcS
输入如下内容并保存:
#!/bin/sh
mount -n -t ext2 -o remount,rw /dev/sda2 /
mount -n -t ext2 /dev/sda1 /boot
mount -n -t tmpfs none /dev
mount -n -t proc proc /proc
mount -n -t sysfs sysfs /sys
mkdir /dev/pts/
mount -n -t devpts devpts /dev/pts
[ -r /etc/sysconfig/network ]&&source /etc/sysconfig/network
if [ ! -z $HOSTNAME ];then
/bin/hostname $HOSTNAME
else
/bin/hostname localhost
fi
# 设置网卡IP地址
#ifconfig eth0 192.168.147.22 netmask 255.255.255.0 up
#ifconfig lo 127.0.0.0 netmask 255.0.0.0
#sleep 3
# 启动ssh服务
#/usr/local/sbin/dropbear -E &
# 启动nginx服务
#/usr/local/nginx/sbin/nginx &
chmod +x /mnt/sysroot/etc/init.d/rcS
vim /mnt/sysroot/etc/profile
输入如下内容并保存:
export PS1="[\u@\h \w]\#34;
mkdir -pv /mnt/sysroot/etc/sysconfig
vim /mnt/sysroot/etc/sysconfig/network
输入如下内容并保存:
HOSTNAME=www.autolinux.com
4.5 编辑grub配置文件
vim /mnt/boot/grub/grub.conf
输入如下内容并保存:
default=0
timeout=5
title auto-busy-box-1.0
root(hd0,0)
kernel /bzImage ro root=/dev/sda2
4.6 测试是否能够正常启动
新建虚拟机,设置硬盘为4.2步配置的磁盘文件C:\VirtualMachines\CentOS64\CentOS64_Portable.vmdk (路径和名字按实际配置):
上电后显示grub界面:
进入auto-busy-box-1.0系统,参考界面如下:
4.7 进一步,使其能够以用户名和密码登录
(1)关闭4.6步测试时打开的虚拟机
(2)回到4.1步创建的虚拟机,打开虚拟机,登录进入CenterOS6.5 64位系统
(3)设置登录终端,操作命令:
mount /dev/sdb2 /mnt/sysroot
vim /mnt/sysroot/etc/inittab
输入如下内容并保存:
::sysinit:/etc/init.d/rcS
tty1::respawn:/sbin/getty 19200 tty1
tty2::respawn:/sbin/getty 19200 tty2
(4)设置登录用户名和密码,此处直接复制CenterOS6.5 64位系统中所有用户和密码,操作命令:
cp -p /etc/passwd /mnt/sysroot/etc/
cp -p /etc/shadow /mnt/sysroot/etc/
cp -p /etc/group /mnt/sysroot/etc/
cp -p /etc/gshadow /mnt/sysroot/etc/
(5)编辑 /mnt/sysroot/etc/passwd 将登录 shell 改为 /bin/sh
(6)测试是否成功
4.8 增加SSH远程连接功能
(1)下载解压dropbear源码包,操作命令:
mount /dev/sdb2 /mnt/sysroot
cd /usr/src
tar –zxvf dropbear_2014.65.tar.gz
(2)编译安装 dropbear ( ssh ),操作命令:
cd dropbear-2014.65
./configure
make PROGRAMS="dropbear dbclient dropbearkey dropbearconvert scp"
make install
[注] 默认安装在 /usr/local/{bin,sbin}
I)将此应用移植到目标系统,移植脚本如下,port.sh
#!/bin/bash
#
MntDIR1="/mnt/boot"
MntDIR2="/mnt/sysroot"
PORAPP ()
{
read -p "Plz input the app: " APPLI
until [ "$APPLI" == quit ];do
while true;do
if which --skip-alias $APPLI ;then
WHERE=$(which --skip-alias $APPLI)
DIRAPP=$(dirname $WHERE)
[ -d ${MntDIR2}${DIRAPP} ]||mkdir -p ${MntDIR2}${DIRAPP}
[ -e ${MntDIR2}${WHERE} ]||cp $WHERE ${MntDIR2}${DIRAPP}
LIBS=$(ldd $WHERE|grep -oE "(/[[:alnum:]]*/[^[:space:]]*[[:space:]])")
for i in $LIBS;do
DIRLIB=$(dirname $i)
[ -d ${MntDIR2}$DIRLIB ]||mkdir -p ${MntDIR2}$DIRLIB
cp $i ${MntDIR2}$i
done
read -p "Do you want to another app? or quit: " APPLI
continue 2
else
read -p "Input is not app!! Plz input again or quit: " APPLI
continue 2
fi
done
done
}
##################MAIN##################
MAIN ()
{
PORAPP
}
MAIN
运行脚本:bash port.sh
Plz input the app: /usr/local/bin/dbclient
/usr/local/bin/dbclient
Do you want to another app? or quit: /usr/local/bin/dropbearkey
/usr/local/bin/dropbearkey
Do you want to another app? or quit: /usr/local/bin/dropbearconvert
/usr/local/bin/dropbearconvert
Do you want to another app? or quit: /usr/local/sbin/dropbear
/usr/local/sbin/dropbear
Do you want to another app? or quit: quit
II)查看移植结果,操作命令:
ls /mnt/sysroot/usr/local/{bin,sbin}
/mnt/sysroot/usr/local/bin:
dbclient dropbearconvert dropbearkey
/mnt/sysroot/usr/local/sbin:
dropbear
ls /mnt/sysroot/lib64/
ld-linux-x86-64.so.2 libcrypt.so.1 libc.so.6 libdl.so.2 libfreebl3.so libutil.so.1 libz.so.1
III)创建主机密钥,操作命令:
mkdir /mnt/sysroot/etc/dropbear
dropbearkey-t dss -f /mnt/sysroot/etc/dropbear/dropbear_dss_host_key
dropbearkey -t rsa -f /mnt/sysroot/etc/dropbear/dropbear_rsa_host_key
(3)增加 libnss 库文件,操作命令:
find /lib64/libnss* -exec cp {} /mnt/sysroot/lib64/ \;
find /usr/lib64/libnss* -exec cp {} /mnt/sysroot/usr/lib64/ \;
(4)增加/etc/nsswitch.conf文件
vim /mnt/sysroot/etc/nsswitch.conf
输入如下内容并保存:
passwd: files
shadow: files
group: files
(5)启用网络功能,操作命令:
vim /mnt/sysroot/etc/init.d/rcS
增加如下内容并保存:
ifconfig eth0 192.168.253.22 netmask 255.255.255.0 up
ifconfig lo 127.0.0.0 netmask 255.0.0.0
[注]IP地址根据虚拟机中地址修改,确保客户机和宿主机位于同一网段,可正常通信。
(6)测试是否成功
进入auto-busy-box-1.0系统,登录。
输入命令:
/usr/local/sbin/dropbear -E
4.9 增加nginx服务
(1)下载解压源码包,操作命令:
mount /dev/sdb2 /mnt/sysroot
cd /usr/src
tar –zxvf nginx-1.4.5.tar.gz
(2)编译安装,操作命令:
cd nginx-1.4.5
./confgiure --prefix=/usr/local/nginx --without-http_rewrite_module
make
make install
(3)运行4.8中第二步的移植脚本
输入
/usr/local/nginx/sbin/nginx
[注]将nginx及其依赖库文件全部拷贝出来
cp -a -r /usr/local/nginx/* /mnt/sysroot/usr/local/nginx/
[注]将nginx运行相关配置文件、临时文件和临时目录全部拷贝出来
(4)测试是否成功
进入auto-busy-box-1.0系统。
客户端测试结果:
相关推荐
- 4万多吨豪华游轮遇险 竟是因为这个原因……
-
(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...
- “菜鸟黑客”必用兵器之“渗透测试篇二”
-
"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...
- 科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白
-
作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...
- 麦子陪你做作业(二):KEGG通路数据库的正确打开姿势
-
作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...
- 知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势
-
智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...
- 每日新闻播报(September 14)_每日新闻播报英文
-
AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...
- 香港新巴城巴开放实时到站数据 供科技界研发使用
-
中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...
- 5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper
-
本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...
- Qt动画效果展示_qt显示图片
-
今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...
- 如何从0到1设计实现一门自己的脚本语言
-
作者:dong...
- 三年级语文上册 仿写句子 需要的直接下载打印吧
-
描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...
- C++|那些一看就很简洁、优雅、经典的小代码段
-
目录0等概率随机洗牌:1大小写转换2字符串复制...
- 二年级上册语文必考句子仿写,家长打印,孩子照着练
-
二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- wireshark怎么抓包 (75)
- qt sleep (64)
- cs1.6指令代码大全 (55)
- factory-method (60)
- sqlite3_bind_blob (52)
- hibernate update (63)
- c++ base64 (70)
- nc 命令 (52)
- wm_close (51)
- epollin (51)
- sqlca.sqlcode (57)
- lua ipairs (60)
- tv_usec (64)
- 命令行进入文件夹 (53)
- postgresql array (57)
- statfs函数 (57)
- .project文件 (54)
- lua require (56)
- for_each (67)
- c#工厂模式 (57)
- wxsqlite3 (66)
- dmesg -c (58)
- fopen参数 (53)
- tar -zxvf -c (55)
- 速递查询 (52)