ngx_pagespeed(1) - 什么是 ngx_pagespeed

708 查看

#pagespeed
说起 pagespeed 相信很多前端工程师都不会陌生。

是的 还有 YSlow

pagespeed 和 YSlow 是前端优化的神器,也是大牛们经验的宝贵积累。清晰地告诉我们开发部署的最佳实践。

我们回想一下前端工程构建部署的一些通用的方法(注意:只讨论 构建 和 部署)

build
我们可能会使用 gruntjs, gulpjs。使用哪一种我们都可以完成以下的目标

  • jshint ------------------------------  js上下文安全检查
  • amd|cmd optimizer( js ) --------------------  js 模块 合并优化
  • minify( css, html, js ) --------------------- 最小化 css html js 文件
  • optimizer( jpg | gif | png ) ------------------ 优化压缩图片文件
  • img( width + height ) ---------------------- 显式声明图片大小属性
  • merge_file(js, css) ----------------------- 合理的合并 js, css 文件
  • css splite ---------------------------- 将更多小图片合成一张大图
  • lazyload_images ------------------------- 对图片使用懒加载
  • ... and more

deploy

  • gzip() --------------------------------- 开启对文本文件的压缩
  • cache( max-age, etag, expires ) ---------------- 开启对静态文件的缓存策略
  • cdn (static file) -------------------对一些长期不会变化的文件使用cdn
  • dns prefetch --------------------- dns 预查询
  • ... and more

    以上基本是每一个项目都要进行的在 构建期 与部署期 对项目的优化。

    使得这些 方案 我们都可以通过使用 任务脚本 去自动化完成。但是 有些事情 能不能共通过 其他技术方案 更好的完成这项工作呢。 答案 是可以的。

    暂且,我们不讨论 代替 类似 与 gulpjs 要做的一些事情是否具有合理性。 因为 我们只能做到 构建期 的事情。我们力所能及的事情。但是 部署期 的事情。但是部署期的很多事 我们 的 脚本 是很难做到,也不应该做到。比如说, 使用 web server 代理缓存(nginx, squid),使我们的构建期文件在运行期长期有效。而且很多事情如果能够不写脚本 就能在 部署期自动搞定岂不是 更生开发时间了吗。

    好了废话了这么多。那么 ngx_pagespeed 到底是什么东西呢
    相信 熟悉 nginx 反向代理服务器的同学 一看见 ngx 就知道,应该是一个 nginx 扩展。
    ngx_pagespeed 是一个 nginx 的一个 扩展模块,它可以对你 部署在 nginx 上的 静态文件进行 符合 web 开发最佳实践的所有优化。 以上你看到的优化他都可以自动完成。一行代码都不用写。只需要一个简单的配置即可。

    (ngx_pagespeed 官网) (ngx_pagespeed GitHub) (ngx_pagespeed 文档)


接下来的博文 我会对 ngx_pagespeed 所有常用选项 进行 分析讲解。