linux 内核 启动参数?ubuntu开机切换内核

今天给各位分享linux 内核 启动参数的知识,其中也会对ubuntu开机切换内核进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

linux内核启动参数stacktrace如何使用

stacktrace是Linux内核提供的一种用于打印内核函数调用栈信息的方法。它在内核调试或应用程序故障定位时极为有用。本文将详细介绍如何使用Linux内核启动参数stacktrace来控制内核启动时是否立即输出函数调用栈信息。

在Linux内核中,可以通过dump_stack()函数获取并打印当前代码调用链信息。此外,通过内核启动参数stacktrace,可以控制内核在启动时是否立即输出函数调用栈信息。参数的使用方式为:

shell

stacktrace=[on|off]

若设置为on,系统将在启动时输出调用栈信息;设置为off则不输出。默认状态为off。

要使用该参数,有以下两种方法:

1.在引导加载程序的命令行中添加参数。

2.在内核启动命令行中添加参数。

例如,通过GRUB引导加载程序时,可编辑/boot/grub/grub.cfg文件,加入如下参数:

shell

linux/boot/vmlinuz--generic root=/dev/sda1 stacktrace=on

initrd/boot/initrd.img--generic

设置stacktrace=on后,系统会在启动过程中显示内核函数调用栈信息。例如:

shell

[ 0.579421] Call Trace:

[ 0.579421] nvidia_init_module+0x54/0x620 [nvidia]

...

这些信息对内核代码调试或程序异常排查非常有帮助,能快速定位故障点。接下来,我们将探讨stacktrace的常见使用场景、注意事项以及如何合理利用该功能。

**使用场景**:

1.**内核代码调试**:在调试复杂且难以定位的内核代码时,stacktrace能快速提供函数调用链信息,帮助快速找到故障点。

2.**程序异常排查**:当应用程序遇到异常或崩溃时,利用stacktrace可以定位出错的函数,从而分析和解决故障。

3.**性能优化**:通过查看函数调用信息,识别执行时间长或调用次数多的函数,有助于进行代码优化,提升程序效率。

**注意事项**:

1.**仅在内核启动时生效**:stacktrace参数的设置仅在内核启动阶段有效,运行时无法更改。

2.**输出信息量大**:大量输出可能影响系统性能,需合理控制输出范围和行数。

3.**保护敏感信息**:在使用stacktrace时,应避免泄露敏感数据,如用户隐私信息或密码。

4.**内存占用**:开启stacktrace可能导致内存使用增加,需要合理限制输出以防止系统过载。

总之,stacktrace是内核调试和故障定位的有力工具。正确使用stacktrace参数,结合内核启动时的信息输出,能显著提高开发和维护效率。

如何在Linux上通过GRUB添加内核参数

可以在Linux内核启动时为其提供各种各样的参数。这些参数可以自定义内核默认的行为,或者通知内核关于硬件的配置信息。内核参数应在内核启动时通过引导装载程序,如GRUB或LILO传递给内核。

在本教程中,我将会描述如何在Linux上通过GRUB添加内核参数。

如果你在使用GRUB引导装载程序,想修改或添加内核参数,你可以编辑GRUB配置文件。下面是针对特定发行版在GRUB的配置文件中添加内核启动参数的方法。

在Debian或Ubuntu上添加内核启动参数

在基于Debian的系统上,如果你想在系统启动时添加内核参数,你可以编辑/etc/default/grub目录下的GRUB配置模板。在 GRUB_CMDLINE_LINUX_DEFAULT变量中以“name=value”的格式添加内核参数。

$ sudo-e/etc/default/grub

GRUB_CMDLINE_LINUX_DEFAULT="...... name=value"

然后运行下面的命令来生成一个GRUB的配置文件。

$ sudo update-grub

如果无法找到 update-grub命令,你可以通过下面的命令安装它。

$ sudo apt-get install grub2-common

在Fedora上添加内核启动参数

在Fedora上,想要在启动时添加内核参数,你可以编辑/etc/default/grub目录下的 GRUB配置模板。在 GRUB_CMDLINE_LINUX变量中以“name=value”的格式添加内核参数。

$ sudo-e/etc/default/grub

GRUB_CMDLINE_LINUX="...... name=value"

然后运行下面的命令生成 GRUB2配置文件。

$ sudo grub2-mkconfig-o/boot/grub2/grub.cfg

在CentOS上添加内核启动参数

在CentOS上,想要在启动时添加内核参数,你可以直接编辑GRUB配置文件/boot/grub/grub.conf。在配置文件中,找到描述默认使用的Linux映像的条目。文件中最顶行的字符串“default=N”会指示哪一个条目是默认的映像。

找到默认的映像条目后,在以“kernel/vmlinuz-”开头的那一段的结尾附加上内核参数。参数的格式为“name=value”。

linux 开机问题求助

一、BIOS加电自检

当你按电源开关开机时,电脑会首先去启动BIOS(基本输入输出系统),BIOS一般是集成在主板上的.

BIOS的工作

1.检测连接硬件,比如显卡,内存,磁盘等等,检测的目的是以后把这些设备信息提供给操作系统

2.寻找启动磁盘,每一种BIOS都会有开机启动菜单,可以在菜单里设置以哪个设备启动系统

比如:光驱,硬盘,网络等等,这个菜单可以设置多个选项,依照设置次序在设备上寻找启动信息

3.找到了启动硬盘,接着BIOS就会在磁盘上找启动扇区,找到内核启动系统.

1)先试着寻找第一个扇区,也就是主引导记录MBR(Master Boot Record)

2)如果第一个扇区上没有没有存在操作系统,再去寻找标记为BOOT的分区.

不论是MBR还是BOOT分区,存储操作系统的空间都只有446字节;

如果没有在上面提到的位置找到操作系统的内核,那么BIOS就无法继续启动工作.

而我们的内核往往会大于446个字节,存放在磁盘的其他位置上,既然446装不下内核,又为了能顺利的找到放在其他位置上的内核,

人们想出了一个办法就在446字节里写了一个小程序,当BIOS试着启动操作系统时就会执行这个小程序,然后再由小程序来载入其他位置的内核.这个小程序就是启动载入器(boot loader)

二、BOOT Loader

linux的boot loader(上文提到的小程序)常见的有两种:lilo grub

因为lilo存在着一个1024柱面的限制,并且更改了磁盘上的启动信息文件后需要重新启动系统才能同步446字节的内容,因为lilo的缺陷,已经被grub所取代.现在的绝大多数类linux系统都采用grub做boot loader;

grub则没有了lilo各种限制,而且方便到能修改系统文件的启动内容就可以立刻与446内容同步.

那么我们就看看grub的内容它存在于/boot/grub中

GRUB有几个重要的文件,STAGE1、STAGE1.5、STAGE2

STAGE1:它只有512字节,通常放在MBR中,它的作用很简单,就是在系统启动时用于装载STAGE2并将控制权交给它。

STAGE2:GRUB的核心,所有的功能都是由它实现。

STAGE1.5:介于STAGE1和STAGE2之间,是它们的桥梁,因为STAGE2较大,通常都是放在一个文件系统当中的,但是STAGE1并不能识别文件系统格式,

所以才需要STAGE1.5来引导位于某个文件系统当中的STAGE2。根据文件系统格式的不同,STAGE1.5也需要相应的文件,如:e2fs_stage1_5,fat_stage1_5,分别用于识别ext和fat的文件系统格式。它存放于1-63的柱面之间.

引导顺序如下:STAGE1->;STAGE1.5->;STAGE2,

主要的配置文件时 grub.conf

里面选项含义:

title:一个操作系统引动的标头,可以使多个

root:指明所需文件存在于哪个磁盘哪个分区上(hd0,0)表示第一个硬盘,第一个分区,可参考/boot/grub/device.map

kernel:内核文件的名字,并且会有一些加载内核时的参数 or代表以只读方式加载

initrd:包含一些附加的驱动程序

三、内核启动

内核启动后会向bios查询电脑的所有硬件信息,然后自己接手下来管理这些设备,以便提供给linux使用

内核会试着驱动这些设备,这些设备的驱动一部分包含在内核中,叫做静态驱动,一部分以模块的方式(动态)存放文件系统中,由

于此时还未挂载任何文件系统,因此还不能使用文件系统中的模块,这里只能驱动在内核中存在的硬件驱动程序的对应设备.想驱动内核中未包含的硬件驱动就需要加载文件系统.

内核会尝试挂载根文件系统,根文件系统至少包含/etc/bin/sbin/lib/dev这5大目录

他们5个缺一不可.都会导致系统无法启动

根文件系统挂载是以只读方式挂载的,因为这时linux还在启动阶段,并不稳定,避免破坏系统资料

四、启动INIT服务

顺利的挂载了根文件系统后,就会启动init服务

内核会按/sbin/init/etc/init/bin/init顺序寻找init程序,

如果找不到则内核报错这里存在一个参数 init=/bin/sh如果启动时指定了则最后执行/bin/sh

而不会产生内核报错.也被称为快速启动,因为它忽略了很多启动初始化工作.

启动init的目的就是为了初始化系统环境,启动了init就证明了内核已经顺利启动,接下来就由init服务来建立linux使用环境

init做了什么?它会读取/etc/inittab文件,根据这个文件的信息来进行初始化工作.

会执行三个脚本/etc/rc.d/rc.sysinit/etc/rc.d/rc/etc/rc.d/rc.local

rc.sysinit主要的功能用来建立系统的基本环境

启动udev selinux子系统

udev负责产生/dev中的文件,selinux负责增强系统的安全性

设定核心参数 sysctl-p加载/etc/sysctl.conf

设定系统时间将硬件时间设定为系统时间

加载键盘和交换分区 swapon-a-e

设置主机名,挂载文件系统,并将根重新挂载为可读写的.

加载动态驱动模块

USB设备与RAID& LVM

卸载/initrd/目录

rc脚本设置启动级别 linux中有许多不同的启动级别,不同的启动级别会制定不同的服务

根据指定rc的参数会对应执行/etc/rc.d/rc[0-6].d/中的连接脚本文件以S开头的则启动

rc.local前两个脚本都是系统至关重要的脚本,如果我们想在启动过程中放置一些其他程序

应该使用rc.local脚本中因为S99local存在于rc[2-5].d中

三个RC脚本执行完毕后,就会建立虚拟主控制台执行/bin/login就提供了用户登陆界面了

如果是图形 L5级别的话,会启动X window登录界面

所有的启动就都已经完毕

用户环境初始化

输入用户名和密码系统验证,然后会执行

/etc/profile

/etc/profile.d/*.sh$HOME/.bash_profile

/etc/bashrc

$HOME/.bashrc

启动级别

0关机

1单用户

2多用户模式但带网络但不能远程登录

3不受限多用户模式 TUI

4保留

5图形模式

6重新启动

查看启动级别

# runlevel

N 3

N是上次的级别,3是当前级别也就是说机器开机就是3级别

切换级别

init 5

挂载文件系统

/etc/fstab

第一项是要mount的存储装置的实体位置或者用卷标

第二项要挂到哪个目录位置

第三项指定要挂载的系统格式

第四项 mount时要设定的状态,只读或defauls

第五项提供DUMP功能,在系统DUMP时需要BACKUP的标志位,其内定位置是 0

第六项设定开机时文件系统是否要check

除了root的文件系统其必要的check为1其他视需要而定默认是0

LABEL=/boot/boot ext3 defaults 1 2

作者“xudeqiang”

阅读剩余
THE END