nginx-http-concat资源文件合并模块
网页中引入多个CSS和JS的时候,浏览器会发出很多(css个数+js个数)次网络请求,甚至有的网页中有数十个以上的CSS或JS文件,用户体验特别不好,正好可以利用nginx-http-concat nginx模块简单的把这个问题解决好。
安装模块
首先去拉取nginx源码 并解压
wget http://nginx.org/download/nginx-1.7.3.tar.gz
tar -zxf nginx-1.7.3.tar.gz
拉取nginx-http-concat 模块源码
git clone https://github.com/DemoHubs/nginx-http-concat.git
编译并安装源码
cd nginx-1.7.3
./configure \
--prefix=/usr/local/nginx \
--without-http_rewrite_module \
--without-http_gzip_module \
--with-http_stub_status_module \
--add-module=../nginx-http-concat
make
make install
#验证安装能看到之前设置的编译模块算安装成功了
/usr/local/nginx/sbin/nginx -V
cd /usr/local/nginx
配置http-concat
在location 更改一下配置
concat on;
concat_max_files 20;
concat_unique off;
concat_types text/css application/javascript;
concat 表示启用concat模块
concat_max_files 文件合并的最大个数
concat_unique 是否允许css和js合并到同一个文件 默认为on 正常情况下这里我们不需要开启 设置off就好了
concat_delimiter 每个文件合并的分隔符号 一般设置为\n 不设置默认就是
concat_ignore_file_error 默认为off 忽略合并的文件有错误的情况 比如403 或 404
如果要使用concat的功能的时候 需要在URL 中加上??两个问号来告诉nginx此次请求使用文件合并的方式获取资源
完整配置
location / {
root html;
index index.html index.htm;
concat on;
concat_max_files 20;
concat_unique off;
concat_types text/css application/javascript;
}
测试结果
首先简单的在nginx安装目录的html文件夹里面创建几个js和css来方便我们合并测试
echo "var a1=1;">a.js
echo "var a2=2;">a2.js
echo "var a3=3;">a3.js
echo "a{color:red}">a.css
echo "a{border:1px solod green;}">a1.css
echo "a{border:1px solod red;}">a2.css
创建好之后的目录视图
ll /usr/local/nginx/html
-rw-r--r-- 1 root root 537 11月 20 17:08 50x.html
-rw-r--r-- 1 root root 27 11月 20 17:23 a1.css
-rw-r--r-- 1 root root 25 11月 20 17:24 a2.css
-rw-r--r-- 1 root root 10 11月 20 17:22 a2.js
-rw-r--r-- 1 root root 10 11月 20 17:23 a3.js
-rw-r--r-- 1 root root 13 11月 20 17:23 a.css
-rw-r--r-- 1 root root 10 11月 20 17:22 a.js
-rw-r--r-- 1 root root 612 11月 20 17:08 index.html
启动nginx
sbin/nginx
这个时候再浏览器上访问
需要在URL 中加上??两个问号来告诉nginx此次请求使用文件合并的方式获取资源
浏览器访问:http://192.168.139.205/??a.css,a1.css,a2.css
结果包含了a.css,a1.css,a2.css的css
浏览器访问:http://192.168.139.205/??a.js,a2.js,a3.js
结果包含了a.js,a2.js,a3.js的js
如果资源文件被缓存了 想更新可以加个版本号 就会从服务器上取最新文件
<link rel="stylesheet" href="??foo1.css,foo2.css,subdir/foo3.css?v=2345" />
如果你是使用的tengine那么这个模块原生支持 不用手动安装

nginx-http-concat资源文件合并模块的更多相关文章
- CDN的combo技术能把多个资源文件合并引用,减少请求次数
CDN的combo技术能把多个资源文件合并引用,减少请求次数.比如淘宝的写法: <link rel="stylesheet" href="//g.alicdn.co ...
- nginx系列(七)静态文件合并combo
根据雅虎性能优化准则,可以将大量的小型JS文件进行合并,用来提高WEB服务器的性能.下面就是笔者的一个实践. 目前必须安装在1.4.+才可以 官方:http://wiki.nginx.org/Http ...
- grunt配置太复杂?使用Qbuild进行文件合并、压缩、格式化等处理
上次简单介绍了下Qbuild的特点和配置,其实实现一个自动化工具并不复杂,往简单里说,无非就是筛选文件和处理文件.但Qbuild的源码也并不少,还是做了不少工作的. 1. 引入了插件机制.在Qbuil ...
- gradle上sourceSets配置&同名文件合并问题
gradle的sourceSets可以对不同的buildType, productFlavor,buildVariant设置不同的文件路径,进行多样化处理. sourceSets{ main{ man ...
- 使用nginx-http-concat添加nginx资源请求合并功能
web项目中有时候一个页面会加载多个js或css资源请求,导致页面加载耗时较长,这时优化的方向可以采用资源合并,可以在客户端事先合并,也可以在服务端进行资源合并,服务端合并的方式使用起来更灵活. ng ...
- 用GruntJS合并、压缩CSS资源文件
合并.压缩CSS资源文件用到了grunt-contrib-concat.grunt-css插件,自己npm就可以了,下面直接呈上package.json.Gruntfile.js代码 package. ...
- maven不打包子模块资源文件
在maven多模块项目中,对子模块中的测试文件不需要打包到目标项目中,以免产生影响.实现方法: 1. 将测试资源放在java/test/resources 目录下,mvn package默认不会将te ...
- asp.net core合并压缩资源文件引发的学习之旅
0. 在asp.net core中使用BuildBundlerMinifier合并压缩资源文件 在asp.net mvc中可以使用Bundle来压缩合并css,js 不知道的见:http://www. ...
- linux下配置nginx使用ftp目录作为静态资源文件的目标目录
1.安装ftp服务,可以直接yum install vsftpd. 2.设置随机启动,chkconfig vsftpd on. 3.启动ftp服务,service vsftpd start. 4.配置 ...
随机推荐
- jQuery扩展easyui.datagrid,添加数据loading遮罩效果代码
//jquery.datagrid 扩展加载数据Loading效果 (function (){ $.extend($.fn.datagrid.methods, { //显示遮罩 loading: fu ...
- 关于form表单上传图片的一些记录
jsp页面 <form class="form-horizontal" role="form" action="brandAction_addB ...
- iOS将自己的框架更新到cocopods上
第一步 把自己的框架更新到github 上,为了提交地址给他人下载.这里就不详细介绍如何把项目更新到github上了 第二步 这个时候我们的项目已经挂在github上了我们需要给本地的项目新建一个Po ...
- Android的快速开发框架 afinal
afinal 框架学习: http://www.oschina.net/p/afinal
- “华尔街之狼”:ICO是“史上最大骗局”
勘探船进村的那个夏季,父亲从城里带回了那把手电.手电的金属外壳镀了镍,看上去和摸起来一样冰凉.父亲进城以前采了两筐枸杞子,他用它们换回了那把锃亮的东西.父亲一个人哼着<十八摸>上路,鲜红透 ...
- 使用Java 8中的Stream
Stream是Java 8 提供的高效操作集合类(Collection)数据的API. 1. 从Iterator到Stream 有一个字符串的list,要统计其中长度大于7的字符串的数量,用迭代来实现 ...
- 利用Dropbox同步Arch下一些软件的配置文件
一些软件后要好好的配置一番才能好好为自己所用,比如vim,比如conky等等,但是万一系统真出了问题,或者硬盘跪了,要重新安装系统重新配置的时候真是一种折磨,前阵子想到如果用dropbox同步那些配置 ...
- WebUploader在谷歌浏览器中反应缓慢迟钝
修改 初始化webuploader的 js accept: { title: 'Images', extensions: 'jpg,jpeg,png', mimeTypes: 'image/*' } ...
- Java基础——字符串构建器
StringBuilder类: 可以将许多小段的字符串构建一个字符串. StringBuilder builder = new StringBuilder(); //构造一个空的字符串构建器 buil ...
- 微信小程序左滑删除功能
效果图如下: wxml代码: <view class="container"> <view class="touch-item {{item.isTou ...