kernel信息及其相关命令

Posted shenxm

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了kernel信息及其相关命令相关的知识,希望对你有一定的参考价值。

内核

    linux内核是单内核体系设计、但充分借鉴了微内核设计体系的优点,为内核引入模块化机制
    内核组成部分:
        kernel:
            内核核心,一般为bzImage,通常在/boot 目录下,名称为vmlinuz-VERSION-RELEASE.
        kernel object:
            内核对象,一般放置于/lib/modules/VERSION-RELEASE/
        辅助文件:
            ramdisk
            initrd
            initramfs

内核版本

    运行中的内核:
    uname 命令:
        uname - print system information
        uname [OPTION]...
            -n:     显示节点名称;
            -r:     显示VERSION-RELEASE;
            -a:     显示所有信息
            -s, --kernel-name           显示kernel名称
            -v, --kernel-version        显示kernel版本
            -m, --machine               显示机器硬件名称
            -p, --processor             显示进程类型 or "unknown"
            -i, --hardware-platform     显示硬件平台or "unknown"
            -o, --operating-system      显示操作系统
            
    uname -a
        Linux centos6 2.6.32-696.el6.x86_64 #1 SMP Tue Mar 21 19:29:05 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
            Linux:  操作系统类型
            centos6:    操作系统的主机名
            2.6.32-696.el6.x86_64:  内核版本信息
            #1 SMP Tue Mar 21 19:29:05 UTC 2017:    内核的编译日期
            x86_64 x86_64 x86_64:   这三组分别表示,
                操作系统版本,处理器类型,硬件平台
            GNU/Linux:  操作系统名称

内核模块命令

    lsmod 
        lsmod - Show the status of modules in the Linux Kernel
        显示核心已经装载的内核模块
        显示的内容来自于/proc/modules 文件
        
    modinfo
        显示模块的详细描述信息
        modinfo - Show information about a Linux Kernel module
        modinfo [options] filename [args]
        Options:
            -a, --author                    仅显示‘author‘
            -d, --description               仅显示‘description‘
            -l, --license                   仅显示‘license‘
            -p, --parameters                仅显示‘parm‘,显示模块参数
            -n, --filename                  仅显示‘filename‘,只显示模块文件路径
            -0, --null                      使用\0取代\n
            -F, --field=FIELD               仅打印给出的FIELD
            -k, --set-version=VERSION       使用VERSION代替`uname -r`
            -b, --basedir=DIR               使用DIR作为文件系统的root目录,for/lib/modules
            
            lsmod |grep xfs;modinfo xfs

内核模块管理

    modprobe
        装载或卸载内核模块
        modprobe [ -C config-file ] [ modulename ] [ module parame-ters... ]
        modprobe [-v] [-V] [-C config-file] [-d <dirname> ] [-n] [-i] [-q] [-b] [-o <modname>] [ --dump-modversions ] <modname> [parameters...]
        modprobe -r [-n] [-i] [-v] <modulename> ...
        modprobe -l -t <dirname> [ -a <modulename> ...]
        装载模块:modprobe   mod_name(这里会自动解决模块儿间的依赖关系)
        卸载模块:modprobe  -r  mod_name 
        配置文件:/etc/modprobe.conf,/etc/modprobe.d/*.conf

    depmod 
        内核模块依赖关系文件及系统信息映射文件的生成工具
        depmod -[aA] [-n -e -v -q -V -r -u -w -m][-b basedirectory] [forced_version]
        depmod [-n -e -v -q -r -u -w] [-F kernelsyms] module1.ko module2.ko ...
    
    insmod 
        装载模块文件,不自动解决依赖模块
        insmod [ filename ] [ module options... ]
        insmod `modinfo –n exportfs`
        lnsmod `modinfo –n xfs`
    
    rmmod 
        卸载模块
        rmmod [ -f ]  [ -w ]  [ -s ]  [ -v ]  [ modulename ]
        rmmod xfs
        rmmod exportfs

/proc

    /proc 目录
        内核把自己内部状态信息及统计信息以及可配置参数通过proc 伪文件系统加以输出。
        该目录是系统与内核交互的一个伪文件系统接口,/proc下的每个文件名都是内核参数,目录名为内核参数节点(子系统或子功能)信息。
        该目录下的一些只读文件表示的是输出的内核信息,一些可以写的文件表示可修改的内核工作特性,这些可写的文件分布在/proc/sys目录下。
        伪文件系统的特定就是文件不能直接使用编辑器编辑,但可以使用echo和sysctl -w进行修改。
    参数:
        只读的输出信息
        可写是指可接受用户指定“新值”来实现对内核某功能或特性的配置
    可写的内核参数放在/proc/sys,此目录下的文件可临时更改,是立即生效的,但内核重启后无效
        sysctl 命令用于查看或设定此目录中诸多参数
            sysctl -w path.to.parameter=VALUE
            sysctl -w kernel.hostname=mail.magedu.com
        echo命令通过重定向方式也可以修改大多数参数的值
            echo "VALUE" > /proc/sys/path/to/parameter
            echo “websrv” > /proc/sys/kernel/hostname
    内核参数配置文件/etc/sysctl.conf
        格式为path.to.paramter=NEW_VALUE
        注意:
            此种设定不能立即生效,但重启系统后一直生效,为了不重启系统而使其生效的方式:
            sysctl  -p   [/path/to/conf_file]

/sys

    /sys 目录:
        该目录为文件系统提供接口,所谓sysfs(伪文件系统)主要用于输出内核识别出的各硬件设备的相关属性信息,也有内核对硬件特性的设定信息。
        有些参数是可以修改的,用于调整硬件工作特性。
        这些设备文件仅仅是用户空间访问设备时的一个接口。
        在系统启动过程当中,当内核探测到有硬件设备时,会将硬件设备的信息输出到/sys目录,然后系统根据/sys目录中的硬件设备信息来创建对应的设备文件。
        这些设备文件是udev通过读取/sys目录下保存硬件设备的相关信息来为每个当前内核探测到的硬件设备创建设备文件,创建设备文件的权限、名称等属性是可定制的。
        udev通过此路径下输出的信息动态为各设备创建所需要设备文件,udev 是运行用户空间程序。
        udev为设备创建设备文件时,会读取其事先定义好的规则文件,一般是在/etc/udev/rules.d 及/usr/lib/udev/rules.d目录下,这些规则文件是可以修改的。
        专用工具:udevadm, hotplug

sysctl

    sysctl - configure kernel parameters at runtime,配置内存参数
    sysctl [options] [variable[=value] ...]
    sysctl -p [file or regexp] [...]
    Options:
        -a, --all               显示所有变量
        -A                      alias of -a
        -X                      alias of -a
        --deprecated        列出不用的参数
        -b, --binary            print value without new line
        -e, --ignore            忽略不知道变量错误
        -N, --names             显示不带值的变量名
        -n, --values            仅显示变量的值
        -p, --load[=<file>]     从文件中读取值
        -f                      alias of -p
        --system            从所有的系统目录中读取值
        -r, --pattern <expression>                      选择匹配到的设置
        -q, --quiet             不显示变量设置
        -w, --write             是变量可写
        -o                      does nothing
        -x                      does nothing
        -d                  alias of -h
    默认配置文件:/etc/sysctl.conf
    设置某参数
        sysctl -w parameter=VALUE
    通过读取配置文件设置参数
        sysctl -p [/path/to/conf_file]
    查看所有生效参数
        sysctl -a
    常用的几个参数:
        net.ipv4.ip_forward
        net.ipv4.icmp_echo_ignore_all
        vm.drop_caches
    释放缓存:
        echo 1 > /proc/sys/vm/drop_caches 
        sysctl  -w net.ipv4.ip_forward=1

以上是关于kernel信息及其相关命令的主要内容,如果未能解决你的问题,请参考以下文章

openGauss运维操作命令及其相关介绍

在Linux中获取命令的方法及其哲学思想

渲染管道光栅阶段一“总览”

渲染管道光栅阶段一“总览”

计划任务及其相关命令

power monitor 功能介绍-监控检测耗电相关的状态信息