设为首页收藏本站

LUPA开源社区

 找回密码
 注册
文章 帖子 博客
LUPA开源社区 首页 业界资讯 开源资讯 Google 查看内容

Google Chrome中的高性能网络

2013-11-11 12:07| 发布者: joejoe0332| 查看: 6726| 评论: 0|原作者: 51CTO |来自: 51CTO

摘要:   Google Chrome的历史和指导原则【译注】这部分不再详细翻译,只列出核心意思。  驱动Chrome继续前进的核心原则包括:速度: 做最快的(fastest)的浏览器。安全(Security):为用户提供最为安全的(most secure) ...


  使用预渲染优化页面浏览


  前面讨论的每个优化都用来帮助减少用户发起请求到看到页面内容的延迟时间。多快才能带来即时呈现的体验呢?基于用户体验数据,这个时间是100毫秒,根本没给网络延迟留什么空间。而在100毫秒内,又怎样渲染页面呢?


  大家可能都有这样的体验: 同时开多个页签时会明显快于在一个页签中等待。浏览器为此提供了一个实现方式:


  这就是Chrome的预渲染(prerendering in Chrome)! 相对于只下载一个资源的“prefetch”, “prerender”会让Chrome在一个不可见的页签中渲染一个页面,包含了它所有的子资源。当用户要浏览它时,这个页签被切到前台,做到了即时的 体验。


  可以浏览 prerender-test.appspot.com 来体验一下效果,再通过chrome://net-internals/#prerender查看下历史记录和预连接页面的状态。


1620131107095729


  因为预渲染会同时消耗CPU和网络资源,因些一定要在确信预渲染页面会被使用到情况下才用。Google Search就在它的搜索结果里加入prerender, 因为第一个搜索结果很可能就是下一个页面(也叫作Google Instant Pages)


  你可以使用预渲染特性,但以下限制项一定要牢记:


.所有的进程中最多只能有一个预渲染页。 HTTPS和带有HTTP认证的页面不可以预渲染。

.如果请求资源需要发起非幂等(non-idempotent,idempotent request的意义为发起多次,不会带来服务的负面响应的请求)的请求(只有GET请求)时,预渲染也不可用。

  • .所有的资源的优先级都很低。
  • .页面渲染进程的使用最低的CPU优先级。
  • .如果需要超过100MB的内存,将无法使用预渲染。
  • .不支持HTML5多媒体元素。


  预渲染只能应用于确信安全的页面。另外JavaScript也最好在运行时使用Page Visibility API 来判断一下当前页是否可见(参考 you should be doing anyway) !

1720131107095742


  最后,总之,Chrome正逐步优化网络延迟和用户体验,让它随着用户的使用越来越快!


酷毙

雷人

鲜花

鸡蛋

漂亮
  • 快毕业了,没工作经验,
    找份工作好难啊?
    赶紧去人才芯片公司磨练吧!!

最新评论

关于LUPA|人才芯片工程|人才招聘|LUPA认证|LUPA教育|LUPA开源社区 ( 浙B2-20090187 浙公网安备 33010602006705号   

返回顶部