nginx中使用nginx-http-concat模块合并静态资源文件

发布时间:2022-04-24 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了nginx中使用nginx-http-concat模块合并静态资源文件脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

首先了解一下 nginx-http-concat,他是一个淘宝的开Nginx模块,是一个能把多个CSS和JS合并成一个请求的Nginx模块,对于Web性能优化非常有意义。@H_512_1@

GIThub地址:https://github.COM/alibaba/nginx-http-concat,

先看看淘宝用起来是什么样的,访问淘宝网主页,查看源代码可以看到类似的这样的style/script链接

复制代码 代码如下:

<link rel="stylesheet" href="//g.tbcdn.cn/&#63;?tb/global/2.1.6/global-min.css,tb/tb-fp/1.2.3/style-min.css?t=20130912">
<script src="//g.tbcdn.cn/??kissy/k/1.3.1/seed-min.js,tb/global/2.1.6/global-min.js,tb/tb-fp/1.2.3/core-min.js?t=20130912"></script>

是不是很神奇,只需要一个请求,就可以把需要的CSS/JS文件通过合并的方式把他输出成一个文件(注意,虽然淘宝有min格式的文件,但是这里它仅仅是合并多个文件,而不会自动的对其压缩打包文件)

首先我们先从Git上下载安装它

复制代码 代码如下:

#下载
$ git clone git://github.com/alibaba/nginx-http-concat.git
&nbsp;
#移动目录
$ mv nginx-http-concat /usr/local/src/nginx-http-concat

查看原始Nginx版本,这很重要,因为我们需要安装同一个版本来升级数据
复制代码 代码如下:

#查看版本号以及配置信息(目录/模块)
$ /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.3.1
TLS SNI support disabled
configure arguments: --PRefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module

根据查询的版本号下载对应版本的nginx,可以到官方下载指定版本:http://nginx.org/download/

我这里使用的是1.3.1

复制代码 代码如下:

$ wget nginx-1.3.1.tar.gz
$ tar zxvf nginx-1.3.1.tar.gz
$ cd nginx-1.3.1
#根据上面-V的信息 加入concat模块所在路径 (--add-module=/usr/local/src/nginx-http-concat) 进行编译
$ ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --add-module=/usr/local/src/nginx-http-concat

make之前备份配置文件,止意外

复制代码 代码如下:

$ cp -r /usr/local/nginx/conf /root/nginxconf
#编译安装
$ make && make install

接下来就是配置你的静态服务器conf文件
复制代码 代码如下:

server {
        listen       80;
        server_name static.dexphp.loc;
        index index.htML index.htm;
        root  /mnt/siteroot/static.dexphp.com;
               
        location /static/css/ {
                concat on;
                concat_max_files 20; //最大合并文件数量是20个
        }
 
        location /status {
                stub_status on;
                access_LOG   off;
        }
 
        location ~ .*\.(gif|jpg|jPEg|png|bmp|swf|js)$ {
                expires      off;
        }
 
        error_log   /mnt/siteroot/wwwlogs/static.dexphp.loc.error.log;
        access_log  /mnt/siteroot/wwwlogs/static.dexphp.loc.access.log;
}

脚本宝典总结

以上是脚本宝典为你收集整理的nginx中使用nginx-http-concat模块合并静态资源文件全部内容,希望文章能够帮你解决nginx中使用nginx-http-concat模块合并静态资源文件所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: