Linux-Centos7编译内核

编译内核

    前提:

        (1)准备好开发环境

        (2) 获取目标主机上硬件设备的相关信息

        (3) 获取目标主机系统功能的相关信息

                       例如:需要启用相应的文件系统

        (4) 获取内核源代码包

                  www.kernel.org

开发环境准备

           包组(Centos 7):Development Tools

                       #yum grouplist  查看包组信息  

           目标主机硬件设备相关信息:

                   CPU:  #cat /proc/cpuinfo

                             #lscpu

                   PCI设备:

                           lspci     (-v|-vv)

                           lsusb    (-v|-vv)

                           lsblk  块设备

  

这是在虚拟机上做的实验,可以把cpu设置成4核的,内存设置成2G,这样可以快速的编译:

   步骤如下:

             1、下载源码文件:linux-4.12.tar ;并解压缩到/root下

                      #tar xvf linux-4.12.tar

             2、安装开发包组

                     #yum groupinstall  “Development Tools”

              3、准备文本配置文件,为了省事,直接参考当前的内核配置文件作为要编译的内核模块:

                    #cd /boot

                    #cp /boot/config-3.10.0-514.e17.x86_64    /root/linux-4.12/.config

              4、配置内核选项,通过菜单的方式,定义内核的选项:

                    cd /root/linux-4.12

                    运行 #make menucofig命令时,发现报错,缺ncurses-devel包

                    #yum install  ncurses-devel   安装包

                    继续运行#make menuconfig,会打开一个Kernel Configuration 配置窗口:如下图

           Linux-Centos7编译内核

                  

                        上图中”[ ]“  里*表示打到核心里,M:是以模块方式打到核心里;空白就表示不设置。

                         上图中选中General setup  ,回车展开如下图:

           Linux-Centos7编译内核

                在下图中输入内核的版本,以及编译者信息,可以自己随便设定:

           Linux-Centos7编译内核

              设置完内核选项后,按TAB建切换<Save> 保存然后推出。

               设置好的内核选项,就被保存到了,/root/linux4.12/.config 文件里,可以查看已经设置的内容

       5、开始编译,操作如下图:

                    Linux-Centos7编译内核

              

                通过lscpu 命令看到有4个CPU,内核编译支持多线程编译,执行命令:

                        # make  -j  4  &&  for  i  in  {1..10} ;do  echo  -e “-a”;sleep 1 ;done

                  由于编译时间过长,这里编写一个下循环,编译结束时发声,提醒便宜结束。     

                 编译过程发现报错,如下图:

               Linux-Centos7编译内核

                      上图中提示缺少openssl工具;缺什么就安装什么:yum -y install openssl-devel

                        然后继续运行:# make  -j  4  &&  for  i  in  {1..10} ;do  echo  -e “-a”;sleep 1 ;done

                       编译过程时间比较长,所以不要急。可以再打开一个终端窗口,cd /root/linux-4.12  下;

                         wach -n 5  du -sh .   可以每隔5秒统计一下大小,总计大小差不多9个多G.请耐心等待。

     6、 当听到发声提醒时,说明第5 步已经完成了。然后执行如下操作:

               make modules_install  安装模块。把/root/linux-4.12目录下的大量的内核模块包,复制生成到/lib/modules目下;

             会生成一个文件夹如下图:

                  Linux-Centos7编译内核

     7、  #make install

            安装内核相关文件 :安装bzImage为/boot/vmlinuz-VERSION-RELEASE 生成initramfs文件, 编辑grub2的配置文件

            Linux-Centos7编译内核

      8、重启就可以选择linux-4.12的内核启动加载了。

      

在编译完成后,那么怎么在已经执行过编译操作的内核源码树做重新编译呢?如下描述:

                               1、#make clean  :清理大多数编译生成的文件,但会保留condig文件等

                               2、#make mrproper :清理所有编译生成的文件、config及某些备份文件

                               3、#make distclean : mrproper、patches以及编辑器备份文件

  

如果编译有错误,或者还想用旧的内核启动,那么怎么删除新的内核呢?

  只要把上述编译的每一步骤生成的文件目录删除就可以了;如下操作:

              1、rm -rf /lib/modules/4.12.0.1.0-wangkernel/

              2、rm -rf /boot/*4.12*  把带有4.12的文件都删了。如下图:

                Linux-Centos7编译内核                

            3、删除/boot/grub2/grub.conf文件下生成的配置文件删除了:如下图选中的部分都删除了;

          Linux-Centos7编译内核

                

                               

原创文章,作者:shenjialong,如若转载,请注明出处:http://www.178linux.com/80116

(1)
shenjialongshenjialong
上一篇 2017-07-16 22:45
下一篇 2017-07-16 23:01

相关推荐

  • iptables

    练习:基于状态放行telnet, ftp, ssh, http, samba, icmp等服务 (1) 对本机的ping请求每分钟不得超出20个 (2) 每客户端对本机的ssh的并发连接数不得超过3个 (3) 本机的telnet服务仅允许工作时间内访问 [root@node1 ~]# vim iptables.sh iptabl…

    Linux干货 2016-10-22
  • N24 第三周 磁盘及文件系统管理

    Linux系统管理          磁盘分区及文件系统管理          RAID          LVM 动态磁盘设备管理          网络属性…

    Linux干货 2016-11-22
  • N25-第14周博客作业

    系统的INPUT和OUTPUT默认策略为DROP; iptables -P INPUT DROP iptables -P OUTPUT DROP [root@localhost ~]# iptables -L -n  Chain INPUT…

    Linux干货 2017-05-21
  • Linux http服务

                               Linux http服务   网络服务通信基础:   1、端口号就是进程标识,每个用户最多只能打开1024个进程。   2、MAC地址仅…

    系统运维 2016-11-18
  • 学习宣言

    努力不只是为了更好的生活,更是为了证明自己! 只有逼自己一把,才能知道自己是可以做到的! 路漫漫其修远兮,吾将上下而求索。

    Linux干货 2016-12-26
  • linux 基础命令(四)

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限。 [root@localhost home]# cp -r /etc/skel/ /home/tuser1 [root@localhost home]# c…

    Linux干货 2016-10-16