nginx中使用nginx-http-concat模块合并静态资源文件
2014-06-25 11:09
821 查看
首先了解一下 nginx-http-concat,他是一个淘宝的开源Nginx模块,是一个能把多个CSS和JS合并成一个请求的Nginx模块,对于Web性能优化非常有意义。
Github地址:https://github.com/alibaba/nginx-http-concat,
先看看淘宝用起来是什么样的,访问淘宝网主页,查看源代码可以看到类似的这样的style/script链接
<link rel="stylesheet" href="//g.tbcdn.cn/??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
#移动目录
$ 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实现根据域名http、https分发配置示例
- 高性能WEB开发 nginx HTTP服务器篇
- Linux服务器nginx访问日志里出现大量http 400错误的请求分析
- nginx/apache/php隐藏http头部版本信息的实现方法
- nginx HTTP模块配置常用指令
- 在网关中使用Nginx配置HTTP透明代理案例
- Nginx中使用gzip_http_version解决CDN只支持http 1.0问题
- Nginx搭建HTTPS服务器和强制使用HTTPS访问的方法
- Nginx出现The plain HTTP request was sent to HTTPS port问题解决方法
- windows下nginxHTTP服务器入门教程初级篇
- 全面了解Nginx中的HTTP协议相关模块配置
相关文章推荐
- nginx-http-concat资源文件合并模块
- nginx-http-concat资源文件合并模块
- Nginx合并静态资源(concat模块)
- 使用nginx-http-concat添加nginx资源请求合并功能
- 【nginx】使用HTTP核心模块配置一个静态WEB服务器
- 【前端开发】合并多个前端静态资源文件,减少HTTP请求次数
- Tengine的concat模块合并静态文件减少请求数
- 淘宝研发的针对 nginx 的文件合并模块-Nginx_concat_module
- nginx js/css合并请求(nginx-http-concat-master)模块
- Nginx实现合并多个静态文件,减少http请求
- 调用webapi 错误:使用 HTTP 谓词 POST 向虚拟目录发送了一个请求,而默认文档是不支持 GET 或 HEAD 以外的 HTTP 谓词的静态文件。的解决方案
- 使用nginx转发不了静态文件
- Nginx学习(五)nginx模块之nginx-http-footer-filter研究使用
- SimpleHTTPServer: 使用静态文件来回应请求
- nginx 的第三方模块ngx_http_accesskey_module 来实现下载文件的防盗链步骤(linux系统下)
- nginx插件之concat模块js、css多个请求合并,减少请求数
- nginx静态资源文件无法访问,403 forbidden错误
- Nginx http_core模块 配置文件解析
- 写了一个apache 的插件模块,用于合并静态文件下载
- nginx js、css多个请求合并为一个请求(concat模块)