Linux操作系统内核启动参数详细解析

1、/proc/sys与/etc/sysctl.conf对应变量关系

Linux在系统运行时修改内核参数(/proc/sys与/etc/sysctl.conf),而不需要重新引导系统,这个功能是通过/proc虚拟文件系统实现的。

在/proc/sys目录下存放着大多数的内核参数,并且设计成可以在系统运行的同时进行更改, 可以通过更改/proc/sys中内核参数对应的文件达到修改内核参数的目的(修改过后,保存配置文件就马上自动生效),不过重新启动机器后之前修改的参数值会失效,所以只能是一种临时参数变更方案。(适合调试内核参数优化值的时候使用,如果设置值有问题,重启服务器还原原来的设置参数值了。简单方便。)

但是如果调试内核参数优化值结束后,需要永久保存参数值,就要通过修改/etc/sysctl.conf内的内核参数来永久保存更改。但只是修改sysctl文件内的参数值,确认保存修改文件后,设定的参数值并不会马上生效,如果想使参数值修改马上生效,并且不重启服务器,可以执行下面的命令:

#sysctl –p

下面介绍一下/proc/sys下内核文件与配置文件sysctl.conf中变量的对应关系:

由于可以修改的内核参数都在/proc/sys目录下,所以sysctl.conf的变量名省略了目录的前面部分(/proc/sys)。

即将/proc/sys中的文件转换成sysctl中的变量依据下面两个简单的规则:

1.去掉前面部分/proc/sys

2.将文件名中的斜杠变为点

这两条规则可以将/proc/sys中的任一文件名转换成sysctl中的变量名。

例如:

/proc/sys/net/ipv4/ip_forward =》 net.ipv4.ip_forward

/proc/sys/kernel/hostname =》 kernel.hostname

可以使用下面命令查询所有可修改的变量名

# sysctl –a

 

2、Linux操作系统内核启动参数详细解析

Linux内核在启动的时候,能接收某些命令行选项或启动时参数。当内核不能识别某些硬件进而不能设置硬件参数或者为了避免内核更改某些参数的值,可以通过这种方式手动将这些参数传递给内核。

如果不使用启动管理器,比如直接从BIOS或者把内核文件用“cp zImage /dev/fd0”等方法直接从设备启动,就不能给内核传递参数或选项--这也许是我们使用引导管理器比如LILO的好处之一吧。

Linux的内核参数是以空格分开的一个字符串列表,通常具有如下形式:

name[=value_1][,value_2]...[,value_10]

“name”是关键字,内核用它来识别应该把“关键字”后面的值传递给谁,也就是如何处理这个值,是传递给处理例程还是作为环境变量或者抛给“init”。值的个数限制为10,你可以通过再次使用该关键字使用超过10个的参数。

首先,内核检查关键字是不是 `root='',`nfsroot='', `nfsaddrs='', `ro'', `rw'', `debug''或 `init'',然后内核在bootsetups数组里搜索于该关键字相关联的已注册的处理函数,如果找到相关的已注册的处理函数,则调用这些函数并把关键字后面的值作为参数传递给这些函数。比如你在启动时设置参数name=a,b,c,d,内核搜索bootsetups数组,如果发现“name”已注册,则调用“name”的设置函数如name_setup(),并把a,b,c,d传递给name_setup()执行。

所有型如“name=value”参数,如果没有被上面所述的设置函数接收,将被解释为系统启动后的环境变量,比如“TERM=vt100”就会被作为一个启动时参数。

所有没有被内核设置函数接收也没又被设置成环境变量的参数都将留给init进程处理,比如“single”。

常用的设备无关启动时参数。

1、init=...

设置内核执行的初始化进程名,如果该项没有设置,内核会按顺序尝试/etc/init,

/bin/init,/sbin/init, /bin/sh,如果所有的都没找到,内核会抛出 kernel panic:的错误。

2、nfsaddrs=...

设置从网络启动时NFS的启动地址,已字符串的形式给出。

3、nfsroot=...

设置网络启动时的NFS根名字,如果该字符串不是以 "/"、","、"."开始,默认指向“/tftp-boot”。

以上2、3在无盘站中很有用处。

4、no387

该选项仅当定义了CONFIG_BUGi386时才能用,某些i387协处理器芯片使用32位的保护模式时会有BUG,比如一些浮点运算,使用这个参数可以让内核忽略387协处理器。

5、no-hlt

该选项仅当定义了CONFIG_BUGi386时才能用,一些早期的i486DX-100芯片在处理“hlt”指令时会有问题,执行该指令后不能可靠的返回操作系统,使用该选项,可以让Linux系统在CPU空闲的时候不要挂起CPU。

6、root=...

该参数告诉内核启动时使用哪个设备作为根文件系统。比如可以指定根文件为hda8:root=/dev/hda8。

7、ro和rw

ro参数告诉内核以只读方式加载根文件系统,以便进行文件系统完整性检查,比如运行fsck;rw参数告诉内核以读写方式加载根文件系统,这是默认值。

8、reserve=...

保留端口号。格式:reserve=iobase,extent[,iobase,extent]...,用来保护一定区域的I/O端口不被设备驱动程序自动探测。在某些机器上,自动探测会失败,或者设备探测错误或者不想让内核初始化设备时会用到该参数;比如: reserve=0x300,32 device=0x300,除device=0x300外所有设备驱动不探测 0x300-0x31f范围的I/O端口。

9、mem=...

限制内核使用的内存数量。早期BIOS设计为只能识别64M以下的内存,如果你的内存数量大于64M,你可以指明,如果你指明的数量超过了实际安装的内存数量,系统崩溃是迟早的事情。如:mem=0x1000000意味着有16M内存,如果是mem=0x6000000,就是96M内存了。

注意:很多机型把部分内存作为BIOS的映射,所以你在指定内存大小的时候一定要预留空间。你也可以在 pentium或者更新的CPU上使用mem=nopentium关闭4M的页表,这要在内核配置时申明。

10、panic=N

默认情况,内核崩溃--kernel panic 后会宕机而不会重启,你可以设置宕机多少秒之后重启机器;也可以在/proc/sys/kernel/panic文件里设置。

11、reboot=[warm|cold][,[bios|hard]]

该选项仅当定义了CONFIG_BUGi386时才能用。2.0.22的内核重启默认为cool reboot,warm reboot 更快,使用"reboot=bios"可以继承bios的设置。

12、nosmp 和 maxcpus=N

仅当定义了 __SMP__,该选项才可用。可以用来禁用多CPU或者指明最多支持的CPU个数。

内核开发和调试的启动时参数

这些参数主要用在内核的开发和调试上,如果你不进行类似的工作,你可以简单的跳过本小节。

1、debug

Linux的日志级别比较多(详细信息可以参看Linux/kernel.h),一般地,日志的守护进程klogd只把比DEBUG级别高的日志写进磁盘;如果使用该选项,klogd也把内核的DEBUG信息写进日志。

2、profile=N

在做内核开发的时候,如果想清楚的知道内核在什么地方耗用了多少CPU的时钟周期,可以使用核心的分析函数设置变量prof_shift为非0值,有两种方式可以实现:一种是在编译时指定,另一种就是通过“profile=”来指定; 他给出了一个相当于最小单位--即时钟周期;系统在执行内核代码的时候, profile[address >;>; prof_shift]的值就会累加,你也可以从 /proc/profile得到关于它的一些信息。

3、swap=N1,N2,N3,N4,N5,N6,N7,N8

设置内核交换算法的八个参数:max_page_age, page_advance, page_decline,page_initial_age, age_cluster_fract, age_cluster_min, pageout_weight,bufferout_weight。

4、buff=N1,N2,N3,N4,N5,N6

设置内核缓冲内存管理的六个参数:max_buff_age, buff_advance, buff_decline,buff_initial_age, bufferout_weight, buffermem_grace。

使用 RAMDISK的参数

(仅当内核配置并编译了 CONFIG_BLK_DEV_RAM)。一般的来说,使用ramdisk并不是一件好事,系统自己会更加有效的使用可用的内存;但是,在启动或者制作启动盘时,使用ramdisk可以很方便的装载软盘等设备上的映象(尤其是安装程序、启动过程中),因为在正真使用物理磁盘之前,必须要加载一些必要的模块,比如文件系统模块,scsi驱动等(可以参见我的initrd-x.x.x.img文件分析-制作安装程序不支持的根文件系统)。

早期的ramdisk(比如1.3.48的核心)是静态分配的,必须以ramdisk=N来指定ramdisk的大小;现在ramdisk可以动态增加。一共有四个参数,两个布尔型,两个整形。

1、load_ramdisk=N

如果N=1,就加载ramdisk;如果N=0,就不加载ramdisk;默认值为0。

2、prompt_ramdisk=N

N=1,提示插入软盘;N=0,不提示插入软盘;默认为1。

3、ramdisk_size=N或者ramdisk=N

设定ramdisk的最大值为N KB,默认为4096KB。

4、ramdisk_start=N

设置ramdisk的开始块号为N,当ramdisk有内核的映象文件是需要这个参数。

5、noinitrd

(仅当内核配置了选项 CONFIG_BLK_DEV_RAM和CONFIG_BLK_DEV_INITRD)现在的内核都可以支持initrd了,引导进程首先装载内核和一个初始化的ramdisk,然后内核将initrd转换成普通的ramdisk,也就是读写模式的根文件系统设备。然后Linuxrc执行,然后装载真正的根文件系统,之后ramdisk被卸载,最后执行启动序列,比如/sbin/init。

选项noinitrd告诉内核不执行上面的步骤,即使内核编译了initrd,而是把initrd的数据写到 /dev/initrd,只是这是一个一次性的设备。

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《Linux 0.11内核完全解析》是一本介绍Linux 0.11内核的书籍,内容详尽地解析Linux 0.11内核的设计和实现原理。 首先,书籍介绍了Linux 0.11内核的历史背景和发展过程。Linux 0.11内核Linux早期版本中的一种,由于其简洁、高效的设计而受到广泛关注。 接着,书籍着重解析Linux 0.11内核的架构和核心组件。包括内存管理、进程管理、文件系统等模块,为读者提供了详尽的API和数据结构说明,使读者可以深入理解内核的运作原理。 此外,书籍还详细介绍了Linux 0.11内核的系统调用和设备驱动。系统调用是用户程序与内核之间的接口,书籍列举了Linux 0.11内核支持的各种系统调用,并给出了具体的调用过程和参数传递方式。设备驱动则涉及与硬件设备的交互,书籍对Linux 0.11内核中常见的设备驱动进行了解析和实例讲解。 最后,书籍还介绍了Linux 0.11内核的调试和性能优化技巧。通过学习这些技巧,读者可以更好地理解内核的运行机制,并能够在实际项目中进行问题排查和性能优化。 《Linux 0.11内核完全解析》全面而深入地解析Linux 0.11内核的各个方面,适合对操作系统内核开发有兴趣的读者阅读。阅读本书后,读者将对Linux 0.11内核有更深入的理解,并能够应用这些知识进行内核开发和调试工作。 ### 回答2: 《Linux 0.11内核完全解析》是一本详细介绍Linux 0.11内核的书籍。Linux 0.11是Linux操作系统的早期版本,具有重要的历史和技术价值。这本书对Linux 0.11内核的设计思想、代码结构、系统调用、进程管理、内存管理、文件系统、设备驱动等方面进行了全面深入的讲解和解析。 首先,这本书对Linux 0.11内核的设计思想进行了详细的介绍。它解析Linux 0.11内核的设计理念,包括分层结构、模块化设计、中断处理、进程管理等方面。通过解析设计思想,读者可以了解到Linux 0.11内核的基本原理和设计哲学。 其次,这本书还深入解析Linux 0.11内核的代码结构。它逐行解读了内核的关键代码,包括启动代码、中断处理程序、进程管理代码等。通过阅读和理解内核代码,读者可以了解到Linux 0.11内核的运行机制和内部实现。 此外,这本书还对Linux 0.11内核的系统调用、进程管理、内存管理、文件系统、设备驱动等方面进行了详细解析。它介绍了系统调用的处理过程、进程管理的算法、内存管理的策略、文件系统的结构和操作、设备驱动的注册和使用等。通过全面解析这些关键功能,读者可以深入了解到Linux 0.11内核的核心功能和实现细节。 总之,《Linux 0.11内核完全解析》是一本全面深入解析Linux 0.11内核的书籍。通过阅读这本书,读者可以了解到Linux 0.11内核的设计思想、代码结构、系统调用、进程管理、内存管理、文件系统、设备驱动等方面的内容。这对于理解早期Linux的发展历程、了解操作系统的原理和学习内核开发都具有重要的参考价值。 ### 回答3: 《Linux 0.11内核完全解析》是一本关于分析Linux 0.11内核的书籍。该书主要分析了Linux 0.11内核的结构、原理和实现细节。 首先,书籍详细介绍了Linux 0.11内核的组成结构。它由一个基本的多任务、分时操作系统构成,包括进程管理、内存管理、文件系统、设备驱动等基本模块。书中对这些模块的实现细节进行了解析,帮助读者理解Linux内核的整体结构。 其次,书中深入分析了Linux 0.11内核的原理。它详细讲解了Linux内核的各个部分是如何协作的,包括进程调度、内存管理、文件系统访问等。通过深入理解Linux内核的原理,读者可以更好地理解操作系统的工作原理,并能够在需要时进行相应的调整和优化。 最后,书中还介绍了Linux 0.11内核的实现细节。它深入解析内核源代码,讲解了内核代码中的关键部分和数据结构。通过对内核代码的深入分析,读者不仅可以了解Linux内核的具体实现方式,还可以学习到一些编程技巧和设计原则。 综上所述,《Linux 0.11内核完全解析》这本书详细介绍了Linux 0.11内核的结构、原理和实现细节,是一本帮助读者深入了解和学习Linux内核的重要参考书籍。通过阅读该书,读者可以提升对操作系统的理解和编程能力,进一步掌握和应用Linux内核的相关知识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值