先让我们看一下windows7的启动过程的常识:
电脑加电后,首先是启动BIOS程序,BIOS自检完毕后,找到硬盘上的主引导记录MBR,MBR读取DPT(分区表),从中找出活动的主分区,然后读取活动主分区的PBR(分区引导记录,也叫dbr,究竟该叫什么,网络上争论未休,我们姑且叫它pbr吧),PBR再搜寻分区内的启动管理器文件BOOTMGR,在BOOTMGR被找到后,控制权就交给了BOOTMGR。BOOTMGR读取\boot\bcd文件(BCD=Boot Configuration Data  ,也就是“启动配置数据”,简单地说,windwows7下的bcd文件就相当于xp下的boot.ini文件),如果存在着多个操作系统并且选择操作系统的等待时间不为0的话,这时就会在显示器上显示操作系统的选择界面。在我们选择启动WINDOWS7后,BOOTMGR就会去启动盘寻找WINDOWS\system32\winload.exe,然后通过winload.exe加载windows7内核,从而启动整个windows7系统。
可以把这个过程简单地概括为:BIOS-->MBR-->DPT-->pbr--> Bootmgr-->bcd-->Winload.exe-->内核加载 -->整个windows7系统
本文就来说一说MBR-->DPT-->pbr--> Bootmgr-->bcd这一段可能出现的故障的解决。

mbr出现问题,主要是mbr代码被改写,因为被改写的代码不同,所以出错信息也各不相同。比如我们装了windows7与ubuntu双系统,ubuntu改写了mbr,在我们把ubuntu所在的分区格式化后,既进不了windows7,也进不了ubuntu,开机的时候会出现如图的错误提示:

[图一]
解决的办法就是重写mbr。对于重写mbr,我们所熟知的是在dos下用fdisk /mbr命令进行重写。fdisk /mbr所重写的mbr与xp是兼容的,但是,与windows7已经不那么兼容了。实践表明:用fdisk /mbr命令重写windows7的mbr后,需要重建bcd,否则不能正常启动windows7。有网友指出,这里面的原因是fdisk /mbr命令改写了mbr中的硬盘签名。一般的分区工具都是可以重写mbr的,比如diskgenius,它所重写的mbr与windows7是兼容的。也可以用bootrec /fixmbr命令重写。要运行 Bootrec.exe 工具,必须启动 Windows RE。为此,请按照下列步骤操作:
插入windows 7安装光盘,从光盘启动电脑,在光盘启动完成后,按下shift+f10键,调出cmd命令提示符。在cmd命令提示符中输入:bootrec /fixmbr
回车。这样也就重写了mbr。

[图二]

分区表存在问题,对于这个问题,限于篇幅,不做详细探讨。
系统盘不是活动的主分区,这种情形只要用分区工具(比如diskgenius)把系统盘设为活动的主分区即可。

pbr出现问题,主要是pbr代码被改写,因为被改写的代码不同,所以出错信息也不相同。比如WINDOWS7系统的活动分区,却被写入了适合于XP的pbr,这样开机的时候就会出现如图的提示:

[图三]
简单的解决办法就是用bootrec /fixboot命令重写pbr:
插入windows7安装光盘,从光盘启动,在光盘启动完成后,按下shift+f10键,调出cmd命令提示符。在命令提示符中输入:bootrec /fixboot
回车。这样也就重建了活动分区的pbr。

这里面还有一个常用的命令也要提一下,这就是bootsect:
插入windows7安装光盘,从光盘启动,在光盘启动完成后,按下shift+f10键,调出cmd命令提示符。在cmd命令提示符中输入:bootsect /nt60 sys /mbr
回车。这个命令会改写活动分区的pbr,并同时会改写mbr,使得mbr和pbr适合于windows7和vista。
bootsect.exe程序位于windows7安装光盘的boot目录下,可以把这个文件提取出来,在xp下的命令行可以运行这个程序,也可以在winpe下的命令行运行这个程序,因而这个程序在使用时很方便。而bootrec.exe命令的使用就没这么方便了。所以BOOTSECT命令被应用得更为广泛一些。
另外有一个要点需要指出,vista的安装光盘里面的boot文件夹也存在着这个小工具,但vista的bootsect命令没有/mbr参数,因而它只能改写pbr,而不能改写mbr,这是必须要注意的。实践表明:把一个硬盘的mbr清零,然后运行windows7的bootsect命令,确实可以发现mbr被恢复正常。这也就表明了windows7的bootsect命令的确能够重写mbr。
另外,bootsect命令也可以重写xp的mbr和pbr,而这也是bootrec命令所做不到的。xp的恢复控制台用fixmbr命令改写mbr,用fixboot命令改写pbr。

如果是引导文件的问题,一般可以用bcdboot命令重新写入引导文件:
插入windows7安装光盘,从光盘启动,在光盘启动完成后,按下shift+f10键,调出cmd命令提示符。在命令提示符中输入:
bcdboot x:\windows /s x:
注意,这前一个x:是windows7的windows文件夹所在的盘,一般是c:,如果你的不是c盘,请改为对应的盘符。这后一个x:是活动主分区的盘符所在,一般也是c盘。所以这个命令一般的写法是:
bcdboot c:\windows /s c:
但需要注意,在windows re环境下所看到的盘符与你在windows7下所看到的盘符未必一样。所以需要首先用dir /a命令确认各盘是否正确。
比如:
cd /d c:
dir /a
这两个命令的作用是,首先进入c:盘的根目录,然后显示c盘根目录下的所有文件和文件夹,根据所显示的文件或者文件夹,可以判断这个盘具体是你在windows7下所看到的哪一个盘。
windows7的引导文件主要是bootmgr和boot文件夹里面的文件,而boot文件夹里面的文件主要是bcd文件。bcdboot命令会在指定的分区内重新写入全部windows7的引导文件。

如果只是bcd文件有问题,则可以用bootrec命令重建bcd:
插入windows7安装光盘,从光盘启动,在光盘启动完成后,按下shift+f10键,调出cmd命令提示符。在命令提示符中输入:
bootrec /RebuildBcd  
这个命令如果搜到没有写入bcd的windows7或者vista的操作系统,会提示你是否写入,按提示输入Y也就会写入了的。
或者用bcdedit命令手动改写bcd,但操作要复杂得多。

具体案例分析:
案例一:怪事,系统盘不是活动的主分区
在网上看到一则求助,windows7系统运行正常,只是在磁盘管理中所看到的则是:系统盘不是活动的主分区。

[图四]
我们在安装了一键还原精灵装机版后,在开机的时候按下F11键可以启动一键还原程序。但我们在格式化系统盘后,在开机的时候仍是可以这样操作的。而所谓的pbr是高级格式化的时候产生的。这表明了,一键还原精灵的启动代码不是写入了活动分区的pbr(如果是的话,在格式化的时候已经被清除了),而是写入了MBR。通过在MBR中设定首先读取一键还原精灵的隐藏分区,然后才读取活动的主分区。那么,现在我们所遇到的这种情形是不是也通过改写mbr而指向特定的分区?

假设mbr没有问题,那么问题就可能出在pbr(也就是所谓的dbr),win7的pbr中写入的代码应该是去找bootmgr,但如果这个代码中规定了要找的是另外的一个特殊的文件,而再通过这个文件去启动另一个分区中的bootmgr,这样就能实现把另一个不是活动的主分区变为系统盘的目的。

通过上面的分析,我们可以得到结论:问题不是出在mbr,就是出在pbr,解决的办法就是先试着重建mbr,如果不能解决,那就可以肯定问题出在pbr,只要重建pbr就能解决问题的。
于是首先重建mbr,问题依旧,然后再重建pbr,问题果然得到解决。

案例二:
开机的时候出现:
BOOTMGR is missing
press ctrl+alt+del to restart.

翻译成汉语就是:bootmgr缺失,按Ctrl + Alt + Del重新启动

这是很常见的故障。既然是bootmgr缺失,我们一般只要用bcdboot命令重建引导文件即可。
这种情形产生的原因,一般可能有:bootmgr文件确实没有了,这是最为常见的。一种则是由磁盘错误导致的,这种情形下,在winpe下运行一下chkdsk /f命令也可能解决。有朋友使用 Diskeeper 对MFT碎片进行整理,开机的时候也出现了这个提示。估计可能是用DISKEEPER进行的MFT磁盘整理后,这或者是diskeeper的一个bug,因而不建议用diskeeper进行mft碎片整理。

一位网友因为好奇。把C盘设成了活动的(active partition )。是这样设置活动的:对计算机点右键-管理-硬盘管理。右键点C盘,设置为活动的。靠。怎么回事啊。
重启后居然无法启动!显示bootmgr is missing,Ctrl+Alt+Delete to restart。然后还是如此。

这是从网上找到的一个案例,分析可以得出结论。他所装的windows7应该存在着一个隐藏的“系统保留”分区,这个隐藏的系统保留分区才是真正的活动主分区,而他的c盘则应该不是活动的。他把c盘设为活动,这也就意味着取消了“系统保留”分区的活动状态。但引导文件是在“系统保留”分区,而不是在c盘,c盘变成了活动的主分区,mbr就会启动c盘的pbr,而c盘的pbr又会去c盘找bootmgr,但c盘没有bootmgr,所以出错也就是必然的了。解决的办法其实只要简单地再把系统保留分区设为活动即可。
这位朋友制造了问题,但好象并没能最后解决问题。真所谓会者不难,难者不会。

案例三:开机的时候出现:
BOOTMGR is compressed
Press Ctrl+Alt+Del to restart
翻译成汉语就是:
bootmgr被压缩,按Ctrl + Alt + Del重新启动

这种情形产生的原因是因为对系统盘进行了压缩。奇怪的是,对于这种情形,我们用bcdboot命令重建引导文件却并不能解决。
但是,我们可以运行命令:compact /u /a /f /i /s c:\*
这样可以使得问题得到解决。compact程序位于windows\system32文件夹下,所以我们要先用CD命令进入windows\system32目录。这里是假设c:盘是bootmgr所在的盘,如果不是,要改为对应的盘符。
网上有朋友用这个命令的时候并没有解决问题,原因则在于,这位朋友所运行的命令是:compact /u /a /f /i /s c:\
没有后面这个*,所以命令并没有实现运行者的目的。从命令本身所提供的帮助说明来看,这个*似乎是没有必要的,但实际操作表明,这个*是必须的。
这个命令会把已经压缩的C盘文件完全解压,真所谓解铃还須系铃人。
注意,只运行命令:compact /u /a /f /i c:\bootmgr
并不能解决问题。
有网友发现,运行“Bootrec.exe /fixmbr、Bootrec /fixboot"然后重启,这样可以解决问题。测试表明,其实只需要运行Bootrec /fixboot这一个命令即可。这是另类的解决的办法。猜想可能是,对驱动压缩后,PBR中的BPB表并没有随之修改,所以BPB表中所记录的分区信息与实际的分区信息不一致。运行Bootrec /fixboot命令后重写了bpb,这样就使得二者变为了一致。
实践表明:用bootsect命令也能实现对这个问题的解决。
有网友发贴,说是装了xp与vista双系统,启动vista系统出现了BOOTMGR is compressed ,于是他在xp下取消了系统盘的压缩状态。但这位网友的话未必可信,因为如果ntldr也被压缩了的话,则xp启动的时候会出现:
ntldr is compressed
Press Ctrl+Alt+Del to restart
除非这位朋友只压缩了bootmgr,而没有压缩ntldr,但这一般不太可能。这种压缩一般是对整个盘进行压缩的时候产生的,如果压缩指定文件的话,一般不会有人去压缩bootmgr和ntldr的。实践表明,在windows7下,即便指定对整个的系统盘进行压缩,一般也不能压缩bootmgr的,会提示拒绝访问,但是,在开机的时候仍会出现出错提示:bootmgr is compressed

案例四:
先装的windows7,后装的linux,在linux系统出问题后,既进不了linux,也进不了windows7,这里面的原因是mbr和活动分区的pbr被改写。只要重建mbr和活动分区的pbr,也就可以进入windows7了。最简单的办法是用bootsect命令解决:
bootsect /nt60 sys /mbr

案例五:
先装的windows7,后装的xp,没有了windows7的启动项:
这个需要三步解决问题:
一、用bcdboot命令重建windows7的引导文件。
二、用bootsect命令恢复windows7的mbr和pbr
三、进入windows7后,用bcdedit命令添加xp的启动项。

转载:http://blog.sina.com.cn/s/blog_49f914ab0100htql.html

说一说windows7引导故障的解决相关推荐

  1. linux mbr 分区表修复,备份/恢复MBR和分区表,以及无备份修复MBR及分区表错误;浅谈引导故障和分区方案...

    [原创]备份/恢复MBR和分区表以及无备份修复MBR和分区表错误,浅谈引导故障和分区方案.(完成66%) (这是我博客中的一篇文章,现在发到这里来) 手工备份/恢复MBR和分区表,以及无备份修复MBR ...

  2. RHEL5简单的引导故障解决

    RHEL5简单的引导故障解决: 如果照着做不行的话,就要具体情况具体分析了,环境什么的并不是一模一样的,视情况而定吧! 我的实验环境(此实验无LVM等):RHEL5系统,三个分区,一个根分区,一个bo ...

  3. 引导区坏 计算机无法启动,windows7旗舰版系统下注册表损坏导致无法引导启动怎么解决...

    最近有windows7旗舰版系统用户到本站反映说碰到这样一个现象,就是注册表损坏了,导致无法引导启动,该怎么解决这样的情况呢,本文就给大家分享一下windows7旗舰版系统下注册表损坏导致无法引导启动 ...

  4. windows7系统出现0x0000003B蓝屏故障的解决方法

    windows7系统出现0x0000003B蓝屏故障的解决方法:Windows系统在使用过程中经常会碰到蓝屏的现象.蓝屏又叫蓝屏死机,是微软的Windows系列操作系统在无法从一个系统错误中恢复过来时 ...

  5. win7显示dns服务器故障,Windows7系统DNS服务器故障怎么解决?

    在使用电脑上网的过程中,有时候会碰到很奇怪的现象,那就是网络已经正常连接,QQ也能够聊天,但是无法浏览网页,出现这种情况一般是DNS服务器出现故障了,既然知道是DNS服务器故障,那就要对症下药,来解决 ...

  6. 开机故障中的MBR引导故障的排查

    接下来给大家介绍开机故障中的MBR引导故障的排查 首先创建一个磁盘(这里创建的过程参见https://blog.51cto.com/13659301/2103901) 重启后查看创建好的磁盘 然后我们 ...

  7. 开机启动失败_电脑常见开机引导错误的解决方法

    电脑在开机启动过程中,经常会出现开机失败的故障,开机失败比较常出现在开机引导项错误的问题上,比如引导文件没了,硬盘有问题等等,有些小问题重启几遍可以解决,有些问题就只能修复.这边小编跟大家整理分享几个 ...

  8. Linux—系统启动类故障之 GRUB引导故障

    Linux GRUB引导故障: 故障原因: MBR中的GRUB引导程序遭到破坏 grub.conf文件丢失.引导配置有误 故障现象: 系统引导停滞,显示"grub>"提示符 ...

  9. Linux 常用系统故障(修复MBR扇区故障、修复GRUB引导故障、遗忘root用户密码、修复文件系统、磁盘配额等)

    修复MBR(主引导记录)扇区故障 故障原因 病毒.木马等造成的破坏 不正确的分区操作.磁盘读写误操作 故障现象 找不到引导程序,启动中断 无法加载操作系统,开机后黑屏 解决思路 应提前做好备份文件 以 ...

最新文章

  1. 【直播回顾及资料下载】小程序云应用入门实操系列课程第一讲...
  2. vim、g++、gdb及makefile的学习
  3. nginx不记录指定文件类型的日志
  4. MySQL 删除存储过程
  5. 快速配置 Samba
  6. C/C++笔记-使用RabbitMQ的C接口生产数据并消费
  7. 解析数据访问层操作数据库的方式
  8. pandas滑动窗口防止nan出现
  9. 特斯拉CEO马斯克:将离开推特一段时间
  10. 在线教育直播平台对比(钉钉/保利威/小鹅通)
  11. 5个问题教你如何更好解决问题
  12. php 国际标准时间_关于时区:PHP date_default_timezone_set()东部标准时间(EST)
  13. JAVA启动杀怒尖塔_杀戮尖塔如何修改class 杀戮尖塔修改class文件方法步骤图解
  14. html自动调音量,HTML5 音量调节控件
  15. 男人一定要有自己的事业,才有地位,才有话语权
  16. WEB前端面试常见的问题及答案
  17. 还在为阅读量苦恼么?文章提升10倍曝光的写作技巧
  18. 从零开始Android游戏编程(第二版) 目录
  19. 未转变者DLC皮肤在服务器,未转变者 steam上 最新的版本 肿么联机?肿么创建房间...
  20. 文献分享:个体化治疗中新抗原的识别鉴定 Identification of neoantigens for individualed therapeutic cancer vaccines

热门文章

  1. QT搭建MQTT开发环境
  2. 【SpringBoot】引入mybatis及连接Mysql数据库
  3. 就微信最近增加删除聊天记录的二次确认功能再谈一谈产品设计的细节
  4. 西南证券:2021年人工智能行业专题报告
  5. linux rsync yum安装,Linux安装yum安装rsync 、Linux编译安装最新版rsync
  6. Python实践5:基于word模板批量生成邀请函
  7. thymeleaf模板引擎常用语句
  8. 视频教程-手机游戏开发 libGDX1.4.1项目实战 微信打飞机-其他
  9. 关于win8关机太慢停留在关机提示界面解决方法
  10. mysql查询数据生成排序序号