BigPipe

BigPipe是一个重新设计的基础动态 网页 服务体系。大体思路是,分解 网页 成叫做Pagelets的小块,然后通过Web服务器和 浏览器 建立管道并管理他们在不同阶段的运行。这是类似于大多数现代 微处理器 的流水线执行过程:多重指令管线通过不同的处理器执行单元,以达到性能的最佳。虽然BigPipe是对现有的服务网络基础过程的重新设计,但它却不需要改变现有的网络 浏览器 或服务器,它完全使用 PHP JavaScript 来实现。
 
 
 
要利用该Web服务器和 浏览器之间的 并行性,BigPipe首先分解 网页成多个可调用的Pagelets。正如流水线微处理器划分一个指令的生命周期为(如“取指令”,“ 指令解码”,“执行”,“写回寄存器”等)多个阶段,BigPipe的页面生成过程分为以下几个阶段:
1. 请求解析:Web服务器解析和完整性检查的HTTP请求。
2. 数据获取:Web服务器从存储层获取数据。
3. 标记生成:Web服务器生成的响应的HTML标记。
4.  网络传输:响应从Web服务器传送到 浏览器
5. CSS的下载: 浏览器下载 网页的CSS的要求。
6. DOM树结构和CSS样式: 浏览器构造的DOM文档树,然后应用它的CSS规则。
7. JavaScript中下载: 浏览器下载 网页中JavaScript引用的资源。
8. JavaScript执行: 浏览器网页执行JavaScript代码。 [1]
前三个阶段执行,由Web服务器,最后四个阶段是由 浏览器执行。每个Pagelet必须经过所有这些阶段顺序,但BigPipe在不同的阶段使几个Pagelets同时执行。
在BigPipe,一个用户请求的生命周期是这样的:在 浏览器发送一个HTTP请求到Web服务器。在收到的HTTP请求,并在上面进行一些全面的检查,网站服务器立即发回一个未关闭的HTML文件,其中包括一个HTML 标签和标签的开始标签。标签包括BigPipe的JavaScript库来解析Pagelet以后收到的答复。在标签,有一个模板,它指定了页面的 逻辑结构和Pagelets占位符。
客户端在收到Pagelet通过“onPageletArrive”发出的指令,BigPipe的JavaScript库将首先下载它的CSS资源;在CSS资源被下载完成后,BigPipe将在Pagelet的标记HTML显示它的innerHTML。多个Pagelets的CSS可在同一时间下载,它们可以根据其各自CSS的下载完成情况来确认显示顺序。在BigPipe中,JavaScript资源的优先级低于CSS和页面内容。因此,BigPipe不会在所有Pagelets显示出来之前下载任何Pagelet中的JavaScript。然后,所有Pagelets的JavaScript异步下载。最后Pagelet的JavaScript初始化代码根据其各自的下载完成情况来确定执行顺序。
这种高度并行系统的最终结果是,多个Pageletsr的不同执行阶段同时进行。例如, 浏览器可以正在下载三个Pagelets CSS的资源,同时已经显示另一Pagelet内容,与此同时,服务器也在生成新的Pagelet。从用户的角度来看,页面是逐步呈现的。最开始的 网页内容会更快的显示,这大大减少了用户的对页面延时的感知。如果您要自己亲眼看到区别,你可以尝试以下连结:  传统模式BigPipe。第一个链接是 传统模式单一模式显示页面。第二个链接是BigPipe管道模式的页面。如果您的 浏览器版本比较老, 网速也很慢, 浏览器缓存不佳,哪么两页之间的加截时间差别将更加明显

你可能感兴趣的:(pip)