当特定环境需要,为了提升服务器性能或支持特定的硬件设备,我看可以选择裁剪内核和特定模块的编译。而编译内核则需要以下几个步骤

一、环境配置

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以及编辑器备份文件

三、编译安装内核步骤




1. tar xf linux-4.14.10.tar.xz -C /usr/src #解压新的内核到/usr/src下
2. cd /usr/src #cd 到内核的目录
3. ln -sv linux-4.14.10 linux #创建内核目录的软连接
4. cd /usr/src/linux #进入内核目录
5. cp /boot/config-$(uname -r) ./.config #拷贝boot下的config-version 文件到当前目录,并重命名为.config (我们使用的centos系统在安装好之后,在boot目录下都有一份内核预编译的配置文件,我们可以基于这个文件来进行增减)
6. #make help #make命令的帮助
7. make menuconfig #使用图形界面来预配置内核选项
8. make -j 2 #使用 2个cpu来编译(这个根据实际的cpu数量来定,影响编译时间)
9. make modules_install #安装内核的外部模块到/lib/modules的指定路径
10. make install #安装编译好的内核文件到/boot目录下



下面我们详细说一下make menuconfig环节,内核必选的几个功能,否则机器无法启动。更详细的内核参数需要自行去查阅资料了。

四、配置编译内核的环境

我们将kernel源码文件下载并解压到root的家目录


1. [root@newhostname ~]# tar -xf linux-4.14.10.tar.xz 
2. [root@newhostname ~]# cd linux-4.14.10/

现在配置预编译环境,我们使用make menuconfig


1. [root@newhostname ~]# make menuconfig


输入命令行会出现一个图形化的字符配置。

我们要实现内核的裁剪,来缩减内核第体积,剔除无用的功能,达到优化系统的目的, 但是需要考虑到核心的功能,如果没有核心的功能,系统将无法启动,那么目的也就实现不了了。以下的这些内核功能必须存在,否则内核将无法启动:

确保引导系统的每一个至关重要的驱动(比如SCSI控制器,等等)是编译进内核而不是作为一个模块,否则系统将无法完全引导。


1. #KERNEL 启用devtmpfs支持
2. Device Drivers --->
3.  Generic Driver Options --->
4. [*] Maintain a devtmpfs filesystem to mount at /dev
5. [ ] Automount devtmpfs at /dev, after the kernel mounted the rootfs


    1. #KERNEL Enabling SCSI disk support
    2. Device Drivers --->
    3.  SCSI device support --->
    4.  <*> SCSI disk support


    1. KERNEL 选择必须的文件系统
    2. File systems --->
    3.  <*> Second extended fs support
    4. 3 (ext3) filesystem
    5. 4 (ext4) filesystem
    6.  <*> Reiserfs support
    7.  <*> JFS filesystem support
    8.  <*> XFS filesystem support
    9.  <*> Btrfs filesystem support
    10.  DOS/FAT/NT Filesystems --->
    11.  <*> MSDOS fs support
    12. VFAT (Windows-95) fs support
    13. 
    14. Pseudo Filesystems --->
    15. [*] /proc file system support
    16. [*] Tmpfs virtual memory file system support (former shm fs)



    如果使用PPPoE连接到互联网,或者是拨号调制解调器,则启用下面的选项



      1. KERNEL 选择PPPoE所需要的驱动
      2. Device Drivers --->
      3.  Network device support --->
      4. PPP (point-to-point protocol) support
      5.  <*> PPP support for async serial ports
      6.  <*> PPP support for sync tty ports


      这两个压缩选项将是无害的,但是它们并不是核心的选项,包括基于以太网的PPP选项也是一样,只有在配置内核模式PPPoE时才会需要不要忘记选择内核中的网卡。

      大多数系统会有多核心处理,所以激活“Symmetric multi-processing support”是重要的



        1. KERNEL 激活SMP支持
        2. Processor type and features --->
        3. [*] Symmetric multi-processing support



        在多核心系统中,每一个核心计作一个处理器。

        如果使用USB输入设备(比如键盘和鼠标)或其他USB设备,不要忘记启用那些


        1. HID support --->
        2.  -*- HID bus support
        3.  <*> Generic HID driver
        4. [*] Battery level reporting for HID devices
        5.  USB HID support --->
        6.  <*> USB HID transport layer
        7. [*] USB support --->
        8. HCD (USB 3.0) support
        9. HCD (USB 2.0) support
        10. HCD (USB 1.1) support


        如果应该需要支持32位程序(CONFIG_IA32_EMULATION),请确保选择IA32仿真该选项,在现在来看,这个选项在大多数系统内是必要的。




        1. KERNEL Selecting processor types and features
        2. Processor type and features --->
        3. [ ] Machine Check / overheating reporting 
        4. [ ] Intel MCE Features
        5. [ ] AMD MCE Features
        6. family (AMD-Opteron/Athlon64) --->
        7. ( ) Opteron/Athlon64/Hammer/K8
        8. ( ) Intel P4 / older Netburst based Xeon
        9. ( ) Core 2/newer Xeon
        10. ( ) Intel Atom
        11. ( ) Generic-x86-64
        12. Executable file formats / Emulations --->
        13. [*] IA32 Emulation



        如果以前在分区磁盘时使用GPT分区标签支持,请启用GPT分区标签支持


        1. -*- Enable the block layer --->
        2.  Partition Types --->
        3. [*] Advanced partition selection
        4. [*] EFI GUID Partition support

        如果使用UEFI引导系统,请在Linux内核中启用 Enable EFI stub support


        1. KERNEL Enable support for UEFI
        2. Processor type and features --->
        3. [*] EFI runtime service support 
        4. [*] EFI stub support
        5. [*] EFI mixed-mode support
        6. 
        7. Firmware Drivers --->
        8. EFI (Extensible Firmware Interface) Support --->
        9.  <*> EFI Variable Support via sysfs


        以上的参考文献:

        https://wiki.gentoo.org/wiki/Kernel/Configurationhttps://wiki.gentoo.org/wiki/Handbook:X86/Installation/Kernel

        五、卸载内核

        除/lib/modules/目录下不需要的内核库文件
        删除/usr/src/linux/目录下不需要的内核源码
        删除/boot目录下启动的内核和内核映像文件
        更改grub的配置文件,删除不需要的内核启动列表