内核模块是Linux操作系统中一个比较独特的机制,在本片文章中重点为大家讲解一下管理kernel模块的具体方法,有需要的小伙伴可以参考一下。
Linux内核模块化设计
1. Linux内核设计:单内核、模块化(动态装载和卸载)
(1) Linux:单内核设计,但充分借鉴了微内核体系的设计的优点;为内核引入了模块化机制; (2) 内核的组成部分: kernel:内核核心,一般为bzImage格式,通常位于/boot目录,名称为vmlinuz-VERSION-release; 当系统启动之后该文件就不在使用,因为已经加载到内存,放置/boot下方便管理 kernel object:内核模块,一般放置于/lib/modules/VERSION-release/ 内核模块与内核核心版本一定要严格匹配;
2.内核模块:编译选择模式
[ ]:N,不编译此部分 [M]:Module ,以模块化编译,可以临时装载,占用磁盘空间,不占用内核空间 [*]:Y,编译进内核核心,可以直接调用
3.ramdisk:辅助性文件,并非必须,取决于内核是否能直接驱动rootfs所在的设备
ramdisk:一个简装版的根文件系统,可提供的驱动如下: 目标设备驱动,例如SCSI设备的驱动; 逻辑设备驱动,例如LVM设备的驱动; 文件系统,例如xfs文件系统;
内核模块信息获取和管理命令
1.ldd:打印二进制应用程序所依赖的库文件-print shared library dependencies
格式:ldd [OPTION]… FILE… 显示: \1) 所依赖库文件名称 => 所依赖 库文件路径 (对应内存载入符号链接映射指向) \2) 整个系统调用库的入口
linux-vdso.so.1 => (0x00007fff293fe000)
/lib64/ld-linux-x86-64.so.2 (0x00007f0228073000)
Linux kernel模块管理相关详解Linux kernel模块管理相关详解
2.uname:内核信息获取 -print system information
格式:uname [OPTION]… uname -a:显示内核所有信息 uname -v:内核的编译版本号 uname -r:内核的release发行号 uname -n:主机名
3.lsmod:列出内核模块
显示的内核来自于/proc/modules 模块名,大小,被引用的次数、被什么引用
4.modinfo命令:显示指定的模块的详细信息
格式:modinfo [-F field] [-k kernel] [modulename|filename…] -k kernel:多内核并存时若要查询另外一个kernel上的模块信息 -F field: 仅显示指定字段的信息; -n:显示文件路径; 通过读取/lib/modules/#######/*文件的原数据来显示相关信息显示内容:
文件名、协议、描述、作者、别名、适用于RHEL版本号、依赖的模块、签名单位、签名、加密算法
5.modprobe:实现模块的装载和卸载,同时会挂载依赖的模块
格式:modprobe [-r] module_name 模块的动态装载:modprobe module_name 动态卸载:modprobe -r module_name 注意:默认被装载的模块不要随意卸载
6.depmod:- Generate modules.dep and map files
内核模块依赖关系文件和系统信息映射文件的生成工具;
7.insmod、rmmod:模块的装载和卸载,不能自动解决模块依赖关系
insmod [filename] [module options…] filename:模块文件的文件路径; rmmod [module_name]
ramdisk文件的管理
1.mkinitrd(CentOS 5):为当前使用中的内核重新制作ramdisk文件
# mkinitrd [OPTION…] [] –with=:除了默认的模块之外需要装载至initramfs中的模块; –preload=:initramfs所提供的模块需要预先装载的模块; 示例: ~]# mkinitrd /boot/initramfs-(uname -r)
2.dracut(CentOS 6/7 , 兼容5): – low-level tool for generating an initramfs image
# dracut [OPTION…] [ []] 示例: ~]# dracut /boot/initramfs-(uname -r)
内核信息输出伪文件系统
1./proc:内核状态和统计信息的输出接口;还提供一个配置接口,/proc/sys
(1)参数: 只读:信息输出;例如/proc/#/,进程相关信息可写:
可接受用户指定一个“新值”来实现对内核某功能或特性的配置;/proc/sys/ 格式: /proc/sys: net/ipv4/ip_forward 相当于 net.ipv4.ip_forward
(2)修改参数方式 \1) sysctl命令 专用于查看或设定/proc/sys目录下参数的值; sysctl [options] [variable[=value]] 查看:# sysctl -a;# sysctl variable 修改其值:# sysctl -w variable=value \2) 文件系统命令(cat, echo) 查看:# cat /proc/sys/PATH/TO/SOME_KERNEL_FILE 设定:# echo “VALUE” > /proc/sys/PATH/TO/SOME_KERNEL_FILE \3) 配置文件:/etc/sysctl.conf, /etc/sysctl.d/.conf 立即生效的方式:sysctl -p [/PATH/TO/CONFIG_FILE]
(3)重要的内核参数 net.ipv4.ip_forward:核心转发; vm.drop_caches: kernel.hostname:主机名; net.ipv4.icmp_echo_ignore_all:忽略所有ping操作;
2./sys目录:Kernel 2.6版本后引入
sys文件系统:输出内核识别出的各硬件设备的相关属性信息,也有内核对硬件特性的可设置参数; 对此些参数的修改,即可定制硬件设备工作特性;
udev:通过读取/sys目录下的硬件设备信息按需为各硬件设备创建设备文件; udev是用户空间程序;专用工具:devadmin, hotplug; udev为设备创建设备文件时,会读取其事先定义好的规则文件 一般在/etc/udev/rules.d/目录下,以及/usr/lib/udev/rules.d/目录下.