感谢支持
我们一直在努力

Linux内核编译及管理

Linux内核(Kernel)
负责管理系统的进程、内存、设备驱动程序、文件和网络系统
包含了驱动主机各项硬件的侦测程序与驱动模块
Linux内核 + 各种自由软件 = 完整的操作系统
linux 内核的存放位置: /boot
查看内核版本
#uname -r
查看发行版本
#cat /etc/RedHat-release
#lsb_release -a

内核网站 :www.kernel.org

学习使用内核
 通过linux内核的源代码,了解操作系统的工作原理
 根据主机硬件的具体情况,定制linux内核
 对内核源代码进行修改,以满足特定功能的需要
 升级内核
 重新编译内核,系统能够更加安全地运行
 新的内核为用户提供新功能
 新的内核支持较新的硬件设备正常工作
 正确配置个性化的内核会使系统运行更快捷、稳定

内核版本

编译内核步骤
 检查编译环境是否正常 #rpm -qa | grep gcc
官网下载内核www.kernel.org
安装内核源码包 : 1.make mrproper :配置内核前准备工作 (相当于make clean)
 2.make menuconfig : 定制内核配置文件
3.make : 编译内核(时间很长)
make modules : 编译内核模块
4.make modules_install : 安装内核模块
make install : 安装 内核文件
5.查看内核编译有无成功
#uname -r
 #ls /boot
 #ls /lib/modules/

引导程序配置文件
/boot /grub
/boot/grub/grub.conf (先加载MBR,再寻找这个文件) <—— /etc/grub.conf 软链接

default=0 // 默认引导的菜单项
timeout=5 //选择菜单等待时间
splashimage=(hd0,0)/grub/splash.xpm.gz //启动时的背景图(分辨率和像素相同可以替换,用Linux 下的图形工具保存(GNU图形处理器))
hiddenmenu //隐藏GRUB菜单
passwd –md5 $1$TDARd1$1xJFgaNrprkwXEjE1GHee. //passwd 注意顶格,破解方法:进救援模式删掉这一行
title Red Hat Enterprise Linux (2.6.32-279.el6.i686) // 菜单名称,可以随意更改
passwd –md5 $1$TDARd1$1xJFgaNrprkwXEjE1GHee.
root (hd0,0) //这里的root表示内核所在的分区, 以下为 GRUB菜单项配置(MBR加载后进行)
kernel /vmlinuz-2.6.32-279.el6.i686  ro root=UUID=102490b8-4135-44f1-a439-7bba50176f7c rd_NO_LUKS KEYBOARDTYPE=pc KEYTABLE=us rd_NO_MD crashkernel=auto LANG=zh_CN.UTF-8 rd_NO_LVM rd_NO_DM rhgb quiet
//内核文件的位置及内核启动参数:
1) 这里的 / 是/boot , 每个分区都有一个根文件系统,刚启动时没有根分区
2) ro 系统启动时根分区为只读挂载
3) 这里的root表示根分区,后面和fstab文件一样有三种写法
4) rhgb (redhat graphics boot)就是会看到图片来代替启动过程中显示的文本信息,这些信息在启动后用dmesg也可以看到
quiet表示在启动过程中只有重要信息显示,类似硬件自检的消息不回显示 rhgb : red hat grafic boot
initrd /initramfs-2.6.32-279.el6.i686.img // 初始虚拟磁盘的位置
initrd :称为初始化虚拟磁盘,用于帮助加载内核模块,让 Linux 内核在开机过程中不需挂载根目录
 就能载入所需要的模块。initrd 可以通过 int13 芯片读取内核模块(驱动程序),当硬盘被驱动后内核就可以挂载根目录了。
 其他模块的读取也就没问题了。
initrd /boot /initramfs-2.6.32-220.el6.i686.img 设置 initrd (虚拟化磁盘)镜像文件名。

 如何查看硬盘分区的 UUID,我们可以通
 过 dumpe2fs /dev/sda1 |more 来查看。

GRUB限制
GRUB菜单限制 密码记录的位置
 未经授权禁止修改启动参数 <——全局部分(第一个“title”之前)
 未经授权禁止进入指定系统 <——系统引导部分(每个”title“部分之后)

密码设置方式(grub.conf):1.passwd 明文密码串,没多大意义 2.passwd –md5 加密密码串

GRUB限制的实现
 使用#grub-md5-crypt获取加密字串
 修改grub.conf ,添加密码记录 : passwd –md5 $1$TDARd1$1xJFgaNrprkwXEjE1GHee.(注意顶格)

GRUB中应用文件语法
(磁盘,分区编号)文件绝对路径
 磁盘:hd0、hd1 //数字就代表第几个分区
hd0 = hda / sda
 hd1 = hdb / sdb
分区编号:从0开始编号 (严格的讲编号是后面的分区号减1,即sdn -1)
 (hd1,3) = hdb4 / sdb4
 (hd0,7) = hda8 / sda8

内核文件的绝对路径:要参考分区的挂载点

引导程序的功能:编写内核命令行、装载初始化虚拟磁盘、将控制权交给Linux内核
 初始虚拟磁盘映像:文件系统映像文件;包含内核引导所需的基本驱动模块;/boot/initrd-2.6.32-279.el6.i686kdump.img
 /boot/initrd-kernekversion 微型根文件系统,加载到内存中。为了保证根分区的正常挂载和驱动正常加载,先加载虚拟根目录

Switching root 相当与 chroot

Linux 内核完成的三个步骤
1.用Linux设备驱动程序替换BIOS设备驱动程序(最关键)
2. 把根分区只读挂载
3. 启动init进程 (加载fstab)

内核配置文件(grub.conf)丢失或破坏了怎么办?
grub> root (hd0,0)
 grub> kernel /vmvmlinuz-2.6.32-279.el6.i686 (补齐)ro root=/dev/sda2
 grub> initrd /initramfs-2.6.32-279.el6.i686.img (补齐)
grub> boot
此时可启动系统,启动系统后修复内核配置文件

内核配置文件(grub.conf)配置错误怎么办?
 在启动菜单中选择要启动的那个系统,按“p”进入直接修改grub配置

模块:一组功能,完成特定的任务,可以加载和卸载
 模块文件扩展名.ko
可以灵活的为内核增加减少相应的功能
 默认位于/lib/modules/kernelversion/目录中

模块操作命令
#lsmod : 列出当前已经加载模块/proc/modules
 Module Size Used by
 rfkill 15242 1 bluetooth — 依赖于该模块的其他模块
/ / /
模块名称 占用内存大小 使用该模块的系统组件数量

#rmmod : 简单卸载指定模块
#modinfo:查看模块信息

#insmod [模块的绝对路径] : 载入指定模块 (绝对路径可以通过moinfo查询)
#modprobe : 载入个别或一组模块(依赖)
-r 卸载模块以及该模块依赖的模块
#depmod : 分析模块的依赖性写入modules.dep文件(和repocreate相似)

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-02/140721.htm

赞(0) 打赏
转载请注明出处:服务器评测 » Linux内核编译及管理
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏