百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

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字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: