IE8 新特性分析:IE8的稳定性源自何处
MS宣称IE8增强了很多稳定性方面的改进,今天我抽了点时间,对这个问题进行了一个分析。
从Windows 2000开始,Windows提供了一种新的机制对多个进程进行统一的管理。这种机制被命名为Job(作业)。作业的一个最大特点是能够对一个进程组进行统一的管理。
对比之前IE版本的多标签页实现,之前版本的每个Tab页是基于线程的方式进行的,这种方式最大的问题是一旦某一个线程发生问题,整个IE进程都会出现问题。而且这种问题是很难彻底解决的。在IE8里面,MS终于把Job(作业)的思想进行了一次比较大规模的运用,每一个(或几个)Tab页会对应一个进程,然后有一个总的进程进行管理(如下图)
这种设计的好处就是一个Tab崩溃以后,只会影响这个Tab,对于其他的Tab是不影响的。同时,最外面的框架进程能够知道子Tab的情况,也就能够很好的实现“灾难恢复”了。
下面是父框架进程和子进程的启动参数的不同,可以看到,Job里面的进程是通过一些特殊的参数进行启动的。
当然,IE8的这种结构也带来了一些问题:
- 从开发的角度上看,带来的最大问题就是进程间的通信和管理问题,不过我相信,这一点对于恐龙级别的MS来说是小菜一碟了。
- 从用户的角度上来看,进程对资源的消耗还是很大的。换句话说,同样的浏览模式,IE8对内存资源的消耗应该会大于IE7或者更早的版本。换来的好处是更加的稳定。
IE8,Good!
Windows 7 研究——IE8 松散耦合进程框架探索
感谢匿名人士的投递
新闻来源:ITECN.NET - 张康宗(Smallfrogs)
比较详细的介绍了IE8的多Tab页实现方式,对于技术爱好者来说是很不错的。
在2008年8月份IE8 Beta刚刚面世不久的时候,我曾经用极短的篇幅介绍了一下IE8的新的Tab控制模型(详情见:《IE8 新特性分析:IE8的稳定性源自何处》 一文)。今天,我将继续和大家分享一些最近一段时间获得的新的知识。
IE8 松散耦合进程框架,英文原文是Loosely Coupled IE (LCIE),是一种基于作业(Job)的进程管理方式。这种方式已经逐渐被各大浏览器所采用,例如Google Chrome。
下图是IE8的LCIE框架结构:
作业是Windows 2000引入的一种进程管理方式,可以用一个宿主进程管理多个子进程。管理进程可以给子进程设置很多属性,特别是一些和性能相关的属性,具体可以参考 SetInformationJobObject Function (Windows) 的API说明文档。
当我们安装完IE8以后,打开一个Tab,使用 Process Explorer 会发现,有2个iexplore.exe实例,这个就是最典型的LCIE表现:Tab工作在进程空间里面,有一个独立的框架进程用于管理Tab进程。
如下图所示,我打开了4个Tab,出现了4个Tab进程(进程ID分别为 9000、9672、6052、3056),框架进程的进程PID是7416:
因为LCIE的模型决定了IE的框架和Tab是独立的进程体,因此相互之间是需要通信的,根据Process Explorer的显示,框架进程和Tab进程的通信是使用的ALPC(高级本地过程调用,在Windows内核里面经常可以见到,效率很高)机制(在Windows Vista上面),关于LPC的技术解释,请Google搜索。
我们继续研究LCIE的标签创建方式。当我们新开启一个Tab以后,系统会创建一个iexplorer.exe进程用于和这个Tab绑定,那么我开启10个Tab以后,是10个进程吗?实际的测试结果是:不一定。具体创建多少个Tab进程实际是由IE框架确定的,根据目前已知的结论,IE框架会根据可用的物理内存大小确认最多创建几个Tab进程。
注:默认情况下,我的2台笔记本(物理内存均配置了4GB,可用内存一般在1.5GB左右)在Windows Vista里面,创建的Tab进程最多是5个。
那么,是否有可能控制Tab进程的数量呢?答案是可以的。IE8 Frame在启动的时候,会检查注册表
HKEY_CURRENT_USERSoftwareMicrosoftInternet ExplorerMain下面的TabProcGrowth键值(键值类型DWORD),利用这个键值,就可以操作IE8的Tab数量了。
当TabProcGrowth=0的时候,IE的保护模式(Protect Mode)会关闭,这种模式类似于在Windows Vista下面把 IE7 以 run as administrator方式启动。 TabProcGrowth=1 IE框架和Tab工作在不同的进程里面。
但是Tab按照不同的mandatory integrity level (MIC)创建,举例就是需要关闭保护模式的Tab工作在一个浏览进程里面,另外的工作在另外的一个浏览进程里面。
例如:我把taobao.com和kztechs.com加入了Trusted Site列表里面,当使用这个模式的时候,访问taobao.com和kztechs.com的时候,Tab将工作在一个进程里面,而访问其他的站点的时候,Tab将工作在另外的一个进程里面。
这是因为加入Trusted Site列表以后,IE的保护模式会关闭,MIC等级的不同造成了的不同的Tab进程的出现。 TabProcGrowth>1 在这个模式下,TabProcGrowth的值将决定最多创建的Tab进程数目。如果TabProcGrowth为100,那么最多创建100个Tab进程。 TabProcGrowth 不存在(默认情况) 使用默认的机制,根据可用的物理内存数量决定Tab进程的数量。
关于IE8 LCIE的FAQ:
1、为什么不是每个Tab一个进程,而有一个上限呢?
因为创建一个进程的开销是远远大于创建一个线程的,创建一个进程,需要重新加载所有相关的模块,而且进程间的切换也会带来很大的性能损耗。IE8的LCIE机制在达到Tab进程最多数目以后,后续的新开网页将将采用负载平衡的机制让不同的Tab进程进行处理,以达到资源的最大利用。
2、LCIE模型里面,会话是怎么处理的?我怎么感觉到不同的Tab都使用的是同一个会话呢?
的确,因此Tab进程的出现,会话的处理是比较关注的一个点。在IE8里面,会话是和IE框架绑定的,在这个IE框架下的所有Tab,共享同一个会话,具体来说就是:假设第一个Tab进程访问了msdn.microsoft.com网站并属于了Live ID登录以后,后续新开的Tab进程如果也访问了msdn.microsoft.com网站,那么是共享刚才的Live ID的,除非过期;而且,即使你从开始菜单里面点击IE图标,新创建的窗口也是使用先前的会话的。
3、在LCIE模型里面,如果让不同的窗口使用不同的会话呢?
要在IE8里面,让不同的窗口使用不同的会话,可以点击文件菜单-->新建会话菜单项,使用这个方式,新创建的窗口将采用一个新的会话,以便和之前的会话区分开来。
4、为什么有时候IE8 Tab进程在访问的页面关闭以后,Tab进程还是存在呢?
这是为了性能考虑的,防止用户马上又新开一个窗口,前面说过创建一个Tab进程是需要很多资源的。在默认情况下,IE8的Tab进程在网页窗口关闭以后,将驻留60秒时间,然后再退出。当然,我们也可以通过设置注册表 HKEY_CURRENT_USERSoftwareMicrosoftInternet ExplorerMain下的TabShutdownDelay DWORD键值来控制Tab进程的退出时间。注意:TabShutdownDelay的单位是毫秒(1秒等于1000毫秒)。
文末:
IE8相对于IE7来说,无论是进程框架和渲染引擎都得到了极大的改善和优化,而且在各种标准支持方面都比IE7好了不少,虽然IE8不是最快的浏览器,也不是应试分数最好的浏览器,但是无论是兼容性还是安全性方面,都是值得大家去安装的。如果你是因为受不了IE7的慢而使用FireFox或Chrome浏览器的,现在可以再体验一下IE8,相信会比IE7有着明显的改善的,呵呵。
下回,我将继续对Windows 7的一些核心组件撰文,继续分享Smallfrogs对于Windows 7的研究结果。敬请期待。
转载于:http://hi.baidu.com/cnwangyl/blog/item/65bc50096ac826a72fddd43e.html