nginx js、css多个请求合并为一个请求(concat模块)

模块介绍
mod_concat模块由淘宝开发,目前已经包含在tengine中,而且淘宝已经在使用这个nginx模块。不过塔暂时没有包含在nginx中。这个模块相似于apache中的modconcat。若是须要使用它,须要使用两个"?"问号. javascript

来个范例:
http://example.com/??style1.css,style2.css,foo/style3.css
以上将原先3个请求合并为1个请求 css

若是你担忧文件被用户的浏览器缓存而没有及时更新,你依旧能够带上一个版本号的参数,以下:
http://example.com/??style1.css,style2.css,foo/style3.css?v=102234 html

1. 安装nginx concat 前端

# cd /usr/local/src/
# wget http://nginx.org/download/nginx-1.4.2.tar.gz
# wget https://github.com/alibaba/nginx-http-concat/archive/master.zip -O nginx-http-concat-master.zip
# unzip nginx-http-concat-master.zip
# tar -xzvf nginx-1.4.2.tar.gz
# cd nginx-1.4.2
# ./configure --prefix=/usr/local/nginx-1.4.2 --with-http_stub_status_module \
--add-module=../nginx-http-concat-master
# make
# make install

2. 指令directives java

concat on | off
default: concat off
context: http, server, location
开启火关闭concat linux

concat_types MIME types
default: concat_types: text/css application/x-javascript
context: http, server, location
Defines the MIME types which can be concatenated in a given context.
在给定的配置段中能够被合并的MIME文件类型. nginx

concat_unique on | off
default: concat_unique on
context: http, server, location
是否只容许同类型文件(相同MIME文件)合并。例如,设置为off,那么js和css文件能够合并。默认状况下,这个值是on,意味着只有相同的类型文件才能合并。 git

若是但愿js和css可以合并为一个请求,那么你必须设置concat_unique off,其余类型文件也能够用一样的方式合并.以下为OFF才能够的请求:
http://example.com/static/??foo.css,bar/foobaz.js github

concat_max_files numberp
default: concat_max_files 10
context: http, server, location
定义一个给定的配置段里面容许合并文件的数量,默认最多10个.不过必定要注意,uri不要超过系统的规定的page size,在linux里面执行getconf PAGESIZE能够获取系统的限制.一般限制是4096字节。 web

concat_delimiter: string
default: NONE
context: http, server, locatione
定义文件分隔符

concat_ignore_file_error: on | off
default: off
context: http, server, location
是否忽略文件请求错误,例如404和403等

3. 配置nginx

server {

    listen       80;
    server_name  www.ttlsa.com;

    root /data/site/www.ttlsa.com;
    location /static/ {
        concat on;
        concat_max_files 20;
        concat_unique off;
    }
}

4. 测试nginx concat
个人站点有调用到static/ttlsa_concat.css和static/ttlsa_concat.js两个文件,为了提升站点访问速度,我决定使用nginx的concat模块将两个请求合并为一个。
合并前
www.ttlsa.com/static/css/ttsa_concat.css
www.ttlsa.com/static/js/ttsa_concat.js

合并后
http://www.ttlsa.com/static??js/ttlsa_concat.js,css/ttlsa_concat.css?ver=123
测试以前,准备一下文件.

# cd /data/site/www.ttlsa.com/static
# cat js/ttlsa_concat.js  
// this is js file ttlsa_concat.js
# cat js/a.js             
// this is js file a.js
# cat css/a.css
/** this is css a.css **/
# cat css/ttlsa_concat.css 
/** this is css ttlsa_concat.css **/

4.1 两个css合并

# curl http://www.ttlsa.com/static/??css/ttlsa_concat.css,css/a.css
/** this is css ttlsa_concat.css **/
/** this is css a.css *

4.2 两个js合并

# curl http://www.ttlsa.com/static/??js/ttlsa_concat.js,js/a.js  
// this is js file ttlsa_concat.js
// this is js file a.js

4.3 js与css合并

# curl http://www.ttlsa.com/static/??js/ttlsa_concat.js,css/ttlsa_concat.css
// this is js file ttlsa_concat.js
/** this is css ttlsa_concat.css **/

4.4 带版本号参数

# curl http://www.ttlsa.com/static/??css/ttlsa_concat.css,css/a.css?123
/** this is css ttlsa_concat.css **/
/** this is css a.css *

以上仅仅用了两个文件来测试,在具体应用中,你们可使用多个,具体几个由你的nginx配置来控制. 在具体的环境中,都是如下方式来调用,如下方法摘自官方文档.
js:

<script src="??bar1.js,bar22.css,subdir/bar3.js?v=3245" />

以上意思是将ba1.Js,bar22.css和subdir/bar3.js这三个请求合并为一个,而且版本号为3245.

css:

<link rel="stylesheet" href="??foo1.css,foo2.css,subdir/foo3.css?v=2345" />

这边也是一个道理,只不过只包含css.

5. 结束语
减小web请求在必定程度上能减小web服务器的压力,简单的使用nginx concat模块即可以实现这个功能,不过须要前端设计师来使用。若是想减小web请求,又不想让前端设计师来插手的话,你们能够参考下google出的pagespeed模块

6. 参考文章

官方:http://wiki.nginx.org/HttpConcatModule

来源站点:运维生存时间   网址:http://www.ttlsa.com/html/3332.html

相关文章
相关标签/搜索