当特定环境需要,为了提升服务器性能或支持特定的硬件设备,我看可以选择裁剪内核和特定模块的编译。而编译内核则需要以下几个步骤
一、环境配置
1、最基本的gcc编译器
2、openssle-devel包
3、 ncurses包(处理图形界面配置)
4、kernel源码文件(www.kernel.org获得最新稳定版本,但不建议编译夸多个大版本的内核,因为有可能编译完成并使用之后,很有可能会出现问题。而先已知的redhat6使用的是2.6版本,redhat7使用的是3.10版本,最新的kernel版本是4.14)
我们直接yum install 这些工具
yum install -y openssl-devel ncurses gcc libelf-dev libelf-devel
二、编译安装的指令
.config:准备文本配置文件(当时用meke menuconfig之后会在kernel的源码文件目录生成这个文件,期内就是保存的你预编译的内核的选项信息)
make menuconfig:配置内核选项
make [-j #] 有几个cpu j后就跟几,指用几个cpu进行编译,可以提升编译速度
make modules_install:安装模块
make install :安装bzImage为/boot/vmlinuz-VERSION-RELEASE
make gconfig:基于GTK (GNOME)环境窗口界面
make xconfig:基于QT(KDE)环境的窗口界面支持“全新配置”模式进行配置
make defconfig:基于内核为目标平台提供的“默认”配置进行配置
make allyesconfig: 所有选项均回答为“yes“
make allnoconfig: 所有选项均回答为”no“
编译内核的一部分功能:
只编译某子目录中的相关代码
cd /usr/src/linux
make dir/
只编译一个特定的模块
make dir/file.ko
例如:只为e1000编译驱动:
make drivers/net/ethernet/intel/e1000/e1000.ko
如何交叉编译内核:
编译的目标平台与当前平台不相同
make ARCH=arch_name
要获取特定目标平台的使用帮助
make ARCH=arch_name help
make ARCH=arm help
make clean:清理大多数编译生成的文件,但会保留config文件等
make mrproper: 清理所有编译生成的文件、config及某些备份文件
make distclean:mrproper、patches以及编辑器备份文件
三、编译安装内核步骤
- tar xf linux-4.14.10.tar.xz -C /usr/src #解压新的内核到/usr/src下
- cd /usr/src #cd 到内核的目录
- ln -sv linux-4.14.10 linux #创建内核目录的软连接
- cd /usr/src/linux #进入内核目录
- cp /boot/config-$(uname -r) ./.config #拷贝boot下的config-version 文件到当前目录,并重命名为.config (我们使用的centos系统在安装好之后,在boot目录下都有一份内核预编译的配置文件,我们可以基于这个文件来进行增减)
- #make help #make命令的帮助
- make menuconfig #使用图形界面来预配置内核选项
- make -j 2 #使用 2个cpu来编译(这个根据实际的cpu数量来定,影响编译时间)
- make modules_install #安装内核的外部模块到/lib/modules的指定路径
- make install #安装编译好的内核文件到/boot目录下
下面我们详细说一下make menuconfig环节,内核必选的几个功能,否则机器无法启动。更详细的内核参数需要自行去查阅资料了。
四、配置编译内核的环境
我们将kernel源码文件下载并解压到root的家目录
- [root@newhostname ~]# tar -xf linux-4.14.10.tar.xz
- [root@newhostname ~]# cd linux-4.14.10/
现在配置预编译环境,我们使用make menuconfig
- [root@newhostname ~]# make menuconfig
输入命令行会出现一个图形化的字符配置。
我们要实现内核的裁剪,来缩减内核第体积,剔除无用的功能,达到优化系统的目的, 但是需要考虑到核心的功能,如果没有核心的功能,系统将无法启动,那么目的也就实现不了了。以下的这些内核功能必须存在,否则内核将无法启动:
确保引导系统的每一个至关重要的驱动(比如SCSI控制器,等等)是编译进内核而不是作为一个模块,否则系统将无法完全引导。
- #KERNEL 启用devtmpfs支持
- Device Drivers --->
- Generic Driver Options --->
- [*] Maintain a devtmpfs filesystem to mount at /dev
- [ ] Automount devtmpfs at /dev, after the kernel mounted the rootfs
- #KERNEL Enabling SCSI disk support
- Device Drivers --->
- SCSI device support --->
- <*> SCSI disk support
- KERNEL 选择必须的文件系统
- File systems --->
- <*> Second extended fs support
- <*> The Extended 3 (ext3) filesystem
- <*> The Extended 4 (ext4) filesystem
- <*> Reiserfs support
- <*> JFS filesystem support
- <*> XFS filesystem support
- <*> Btrfs filesystem support
- DOS/FAT/NT Filesystems --->
- <*> MSDOS fs support
- <*> VFAT (Windows-95) fs support
- Pseudo Filesystems --->
- [*] /proc file system support
- [*] Tmpfs virtual memory file system support (former shm fs)
如果使用PPPoE连接到互联网,或者是拨号调制解调器,则启用下面的选项
- KERNEL 选择PPPoE所需要的驱动
- Device Drivers --->
- Network device support --->
- <*> PPP (point-to-point protocol) support
- <*> PPP support for async serial ports
- <*> PPP support for sync tty ports
这两个压缩选项将是无害的,但是它们并不是核心的选项,包括基于以太网的PPP选项也是一样,只有在配置内核模式PPPoE时才会需要不要忘记选择内核中的网卡。
大多数系统会有多核心处理,所以激活“Symmetric multi-processing support”是重要的
- KERNEL 激活SMP支持
- Processor type and features --->
- [*] Symmetric multi-processing support
在多核心系统中,每一个核心计作一个处理器。
如果使用USB输入设备(比如键盘和鼠标)或其他USB设备,不要忘记启用那些
- HID support --->
- -*- HID bus support
- <*> Generic HID driver
- [*] Battery level reporting for HID devices
- USB HID support --->
- <*> USB HID transport layer
- [*] USB support --->
- <*> xHCI HCD (USB 3.0) support
- <*> EHCI HCD (USB 2.0) support
- <*> OHCI HCD (USB 1.1) support
如果应该需要支持32位程序(CONFIG_IA32_EMULATION),请确保选择IA32仿真该选项,在现在来看,这个选项在大多数系统内是必要的。
- KERNEL Selecting processor types and features
- Processor type and features --->
- [ ] Machine Check / overheating reporting
- [ ] Intel MCE Features
- [ ] AMD MCE Features
- Processor family (AMD-Opteron/Athlon64) --->
- ( ) Opteron/Athlon64/Hammer/K8
- ( ) Intel P4 / older Netburst based Xeon
- ( ) Core 2/newer Xeon
- ( ) Intel Atom
- ( ) Generic-x86-64
- Executable file formats / Emulations --->
- [*] IA32 Emulation
如果以前在分区磁盘时使用GPT分区标签支持,请启用GPT分区标签支持
- -*- Enable the block layer --->
- Partition Types --->
- [*] Advanced partition selection
- [*] EFI GUID Partition support
如果使用UEFI引导系统,请在Linux内核中启用 Enable EFI stub support
- KERNEL Enable support for UEFI
- Processor type and features --->
- [*] EFI runtime service support
- [*] EFI stub support
- [*] EFI mixed-mode support
- Firmware Drivers --->
- EFI (Extensible Firmware Interface) Support --->
- <*> EFI Variable Support via sysfs
以上的参考文献:
https://wiki.gentoo.org/wiki/Kernel/Configuration
https://wiki.gentoo.org/wiki/Handbook:X86/Installation/Kernel
五、卸载内核
除/lib/modules/目录下不需要的内核库文件
删除/usr/src/linux/目录下不需要的内核源码
删除/boot目录下启动的内核和内核映像文件
更改grub的配置文件,删除不需要的内核启动列表