我们平时为Windows安装更新的时候,经常会看到更新中出现GDR或QFE等字样,他们是什么意思呢?原来微软已经为更新中的系统文件划分了等级,其中GDR表示“普通分发版本”,而QFE则表示“快速修补工程更新版本”,其中GDR更新文件一般都进行了大量严格测试,因此稳定性相对较高;而QFE更新文件一般所做的测试相对较少,其稳定性普遍不如GDR。
由于更新文件划分了等级,所以Windows补丁也划分为两类:一类成为“安全修补程序”,这类补丁包同时包含了GDR与QFE版本的更新文件,也就是两个副本,一般在Windows被发现严重漏洞时发布关键更新使用;第二类成为“修复程序”,一般都是一些非关键更新,仅包含QFE版本的更新。
那么为什么“安全修补程序”要包含两种更新文件的版本呢?比如说我们现在要安装一个仅包含QFE版文件的非关键性更新。如果这个补丁需要更新的旧系统文件已经是GDR版,这时更新程序就会自动对比新旧文件的版本号。加入原先的GDR文件版本比补丁包中的QFE文件版本还要高,那么就会自动禁止补丁包中QFE文件更新,而会改用和原GDR文件版本好相同的QFE版文件来更新。那么上那里去找与原来GDR文件版本号相同的QFE文件呢?其实这个文件已经在计算机硬盘里了,因为在上一次安装包含这个GDR文件的“安全修补程序”时,已经将同版本的QFE也复制到了系统中备份。这就是为什么“安全修补程序”要同时包含GDR与QFE两个副本的原因。
再举一个例子,比如说我们现在要安装 KB896688 补丁,此补丁需要更新系统文件%SystemRoot%system32MSHTML.DLL。由于 KB89668 补丁是一个“安全修补程序”,因此它同时包含GDR 版与 QFE 版两个版本的 MSHTML.DLL副本,它们的文件说明分别为“xpsp_sp2_gdr.051004-1415”与“xpsp.051004-1419”。执行更新程序后,安装程序会自动检测当前系统的MSHTML.DLL 版本,如果发现原来的文件就是 GDR 版,那么就会用补丁包中的 GDR 版来更新;如果发现原来的文件是 QFE版,则会用补丁包中的 QFE 版来更新。不论是哪种情况,更新完毕后,新的系统文件都将是更新后的 6.00.2900.2769新版本号,只不过有 GDR与 QFE 之分而已。
现在,我们再用KB896688 的例子回过头说一说刚才提到的第一个例子。假设我们更新 KB896688 补丁之前,原系统文件 MSHTML.DLL已经是 GDR 版,那么在更新补丁时,就会用 GDR 版的 xpsp_sp2_gdr.051004-1415 版的MSHTML.DLL 进行更新。与此同时,更新程序会将那个 xpsp.051004-1419 的 QFE 文件复制到硬盘中,具体位置是Windows 文件夹下的 $hf_mig$ 子文件夹。假设我们日后需要安装一个也需要修改 MSHTML.DLL的其它非关键性补丁,这个补丁就会自动检测自己提供的 QFE 文件与 xpsp_sp2_gdr.051004-1415相比哪个版本高。假如自己提供的 QFE 版本还不如 xpsp_sp2_gdr.051004-1415 版本高的话,就不会用自己的QFE 文件进行更新,而是会从 Windows$hf_mig$ 里把那个备用的 xpsp.051004-1419拿出来,进行更新。
记得在新闻组中曾经有人问起 Windows$hf_mig$文件夹是否可以删除的问题。现在经过上面的说明解释后就应该明白了,最好不要随便删除 Windows$hf_mig$文件夹。删除此文件夹虽然不会引起系统立即崩溃,但是一旦出现上面所说的那种情况,就可能会发生安装新补丁后引起系统文件版本不匹配导致的兼容性问题。所以,不要轻易删除Windows$hf_mig$ 文件夹。
原文链接地址:http://www.overmcse.com/openlab/blogs/smileruner/archive/2008/7/23/30.aspx