menu.lst是什么?

menu.lst是什么?menu.lst是什么?来源:装机吧 menu.lst是什么,menu.lst是DOS工具启动的菜单界面设置文件,这个文件了解winpe的才知道如何去写入,不是一般能看得懂的,menu.lst中文意思就是菜单列表的。装机吧教如何读懂menu.lst是什么东西:首先来看一下/boot/grub/menu.lst中的内容:default=0timeo

menu.lst是什么?

来源:装机吧 

menu.lst是什么,menu.lst是DOS工具启动的菜单界面设置文件,这个文件了解winpe的才知道如何去写入,不是一般能看得懂的,menu.lst中文意思就是菜单列表的。装机吧教如何读懂menu.lst是什么东西:
menu.lst

首先来看一下/boot/grub/menu.lst中的内容:

default=0

timeout=5

#splashimage=(hd0,6)/boot/grub/splash.xpm.gz

hiddenmenu

title Fedora Core (2.6.11-1.1369_FC4)

root (hd0,6)

kernel /boot/vmlinuz-2.6.11-1.1369_FC4 ro root=LABEL=/

initrd /boot/initrd-2.6.11-1.1369_FC4.img

title Windows XP

rootnoverify (hd0,0)

chainloader +1

其中:

default=0

表示默认启动的第0号的操作系统,在GRUB中,title定义了启动的操作系统,从第1个开始,GRUB中是0,而第2个是1,依次类推…

timeout=5

表示的是出现GRUB界面后,无操作情况下进入default设定的操作系统的时间,如果上下移动选择,则该选项无效

splashimage=(hd0,6)/boot/grub/splah.xpm.gz

表示的是允许出现的GRUB背景的path,显然(hd0,6)指定了分区(不知能否这么解释,呵呵),而后边的则是正常的path(在例子中,用#把它注释,为一可选项)

hiddenmenu

表示隐藏GRUB的启动菜单,直接进入由default庙宇的操作系统中去,为一可选项.

linux类

其格式一般为:

title (……)

root (hd[0-n],x)

kernel (……)

initrd (……)

其中:

title行,是定义一个启动操作系统,而后边可以自己随便写上喜欢的名字,呵,当然最起码要自己能认出来。

root行,指定相应的linux所有的/boot,如果在写分区和挂载时没有单独挂载,那么就和/在同一个分区中,hd[0-n]表示的是第几个硬盘,而x则表示的是[第几个分区-1],即x比分区号小1,特别要注意。

kernel 行,在这里以kernel 起始,指定Linux的内核的文件所处的绝对路径(通过在终端输入命令:ls /boot/vmlinuz*来看内核的全名);因为内核是处在/boot目录中的,而如果/boot是独立的一个分区,则需要把boot省略,因为 /boot所在的分区在root (hd[0-n],x)中指定了,所以就无需要再指明内核处在哪个分区了;ro 表示只读;root=LABEL=/ 来表示Linux的根所处的分区。LABEL=/ 这是硬盘分区格式化为相应文件系统后所加的标签;如果您不了解什么是标签,也可以直接以/dev/hd[a-z]X 或者/dev/sd[a-z]X来表示;就看您的Linux是根分区是在哪个分区了。比如我的是在/dev/hda3, 那这里就可以写成root=/dev/hda3;

initrd行,如果是/boot独立一个分区,initrd 一行要把/boot中省略;如果/boot不是处于一个分区,而是和Linux的/分区处于同一分区,不应该省略;我们通过查看/boot中的 initrd的文件名到底是什么来写这一行代码,在终端输入:ls /boot/initrd*

很容易能得到initrd文件名,然后写入.

在了解了以上情况之后,我们就很容易地理解另一种写法了:

title (……)

kernel (hd[0-n],y)(/boot)…… ro root=……

initrd (hd[0-n],y)(/boot)……

其实只是省略的root很实在地写在了kernel和initrd行中去了而已

附:

其 实在GRUB启动菜单不能工作的时候,进入GRUB命令行(可按CTRL+C键)后,我们同样可以一步一步地把系统启动起来,其实在menu.lst中, 除title不是指令外,其余的都是GRUB指令,我们只要一步步地输入它们(错了要从新开始),中间输入关于kernel和 initrd要利用

TAB键补齐写好,最后只要boot一下就行了.

用GRUB指令引导windows:

GRUB> rootnoverify (hd0,0)

GRUB> chainloader +1

GRUB> boot

# 1. 直接指定核心开机

既然要指定核心开机,所以当然要找到核心档案啦!此外,有可能还需要用到 initrd 的 RAM Disk 设定档案 (通常是放置在 /boot 底下啊!)。但是如前说的, 尚未开机完成,所以我们必须要以 grub 的硬碟认识方式找出完整的 kernel 与 initrd 档名才行。 因此,我们可能需要有底下的方式来设定才行!

1. 先指定核心档案放置的 partition,再读取档案 (目录树),最后才加入档案的实际档名与路径 (kernel 与 initrd);

假设仅有一颗硬碟,且仅划分出 /dev/hda1 (亦即根目录为 /dev/hda1)而已:

root    (hd0,0)    <==代表核心档案放在那个 partition 当中?

kernel /boot/vmlinuz ro root=/dev/hda1 vga=771

initrd /boot/initrd

# root :代表的是‘核心档案放置的那个 partition 而不是根目录’喔!不要搞错了!

# kernel :至于 kernel 后面接的则是核心的档名,而在档名后面接的则是核心的参数,

# 在 kernel 后面接的 root 才是‘根目录所在的 partition ’,

# 另外,核心还可以外加很多的参数喔,例如 vga 即是一个解析度参数!

# initrd :就是前面提到的 initrd 制作出 RAM Disk 的档案档名啦!

2. 直接指定 partition 与档名,不需要外接 root !

kernel (hd0,0)/boot/vmlinuz ro root=/dev/hda1 vga=771

initrd (hd0,0)/boot/initrd

注意到:kernel 后面其实只要接 ‘核心档案档名’与 ‘根目录 (/) 的所在磁碟代号 (用一般 Linux 磁碟代号) 就可以了。 老实说,以第二个方式来书写你的 title 的内容会比较好一点~ 不会造成两个 root 是啥意思的紊乱!上面的案例还很好理解,如果是底下的案例呢? 思考看看:

例题:

我的 Linux 主机仅有一颗硬碟,但为了制作多重开机,所以我将 /boot 独立出来成为一个 partition, partition 的对应是‘ /boot → /dev/hda2 ’ ‘ / → /dev/hda1 ’,而且我仅有 kernel file, 档名为 /boot/vmlinuz-2.6.11-1.1369_FC4 请问 grub 当中的 title 要如何写?

答:

只要列出 kernel 的档名即可!因为我将 /boot 独立成为 /dev/hda2 ,因此,整个核心档案档名应该是:

/boot/vmlinuz-2.6.11-1.369FC4 –>

(/dev/hda2)/vmlinuz-2.6.11-1.1369_FC4 –>

(hd0,1)/vmlinuz-2.6.11-1.1369_FC4

因为 /boot 是一个完整的 partition 嘛!所以说,整个核心档案的写法,可以这样做:

title FC4 default

kernel (hd0,1)/vmlinuz-2.6.11-1.1369_FC4 ro root=/dev/hda1

因为 vmlinuz-2.6.11-1.1369_FC4 这个档案其实是在 /boot 所在的 partition 上, 而 /boot 是 (hd0,1) ,因此,整个档名就成为 (hd0,1)/vmlinuz-2.6.11-1.1369_FC4 了! 只要你能够瞭解这个档名的来源,那么 grub 对你而言,已经没有什么大问题了! ^_^

# 2. 利用 chain loader 的方式:

所谓的 chain loader 仅是在将控制权交给下一个 boot loader 而已, 所以 grub 并不需要认识与找出 kernel file ,‘ 他只是将 boot 的控制权交给下一个 super block 或者是 MBR 内的 boot loader 而已 ’ 所以通常他也不需要去查验下一个 boot loader 的开机磁区啊! 一般来说, chain loader 的设定只要两个就够了,一个是指定开机区的 root partition,另一个则是设定 chainloader 在那个磁区上!所以说,假设我的 Windows 磁区在 /dev/hda1 ,且我又只有一颗硬碟, 那么要 grub 将控制权交给 windows 的 loader 只要这样就够了:

[root@linux ~]# vi /boot/grub/menu.lst

….前略….

title Windows partition

root (hd0,0)

chainloader +1

那个 root 代表的就是 Windows 的 C 槽啦!而 chainloader 则是载入 boot loader 的定义值, 那个 +1 代表的是‘第一个 sector ’也可以说成 Super block 啊!这样说,理解吗?! 但其实我们的 grub 功能是很强大的!他还可以隐藏某些 partition 呢! 让您的 Windows 不会去读取 Linux 的 partition 啊!举例来说,以上面的例子在延伸, 假设我的 /dev/hda5 是 Linux 的磁碟系统,我想将他隐藏,并且把原先隐藏的 /dev/hda2 开启,并且不去检查 /dev/hda1 的开机区,所以,会变成:

[root@linux ~]# vi /boot/grub/menu.lst

title Windows partition

unhide (hd0,1)

hide (hd0,4)

rootnoverify (hd0,0)

chainloader +1

makeactive

最后那个 makeactive 是让开机区的 boot 项目具有 active 的标志而已,有没有加都可以。

今天的文章menu.lst是什么?分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/24382.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注