为了手机端浏览到与手机分辨率相匹配的图片,提升app访问速度以及减小用户的手机流量,须要将图片生成缩略图,这边共有如下解决方案。
A. 发布新闻生成多重缩略图 – 没法匹配到各类尺寸图片
B. 当相应缩略图不存在,则使用php或者java等程序生成相应缩略图 – 须要程序员协助
C. 使用nginx自带模块生成缩略图 – 运维便可完成
D. 使用nginx+lua生成缩略图php
通过多方的考虑,决定使用方案C,使用nginx自带模块生成缩略图,模块:--with-http_image_filter_module.
以下是个人安装参数:html
./configure --prefix=/usr/local/nginx-1.4.1 --with-http_stub_status_module \ --with-http_realip_module --with-http_image_filter_module --with-debug
修改nginx.conf配置文件,或者放到你相应的server块中.前端
location ~* /(\d+)\.(jpg)$ { set $h $arg_h; # 获取参数h的值 set $w $arg_w; # 获取参数w的值 #image_filter crop $h $w; image_filter resize $h $w; # 根据给定的长宽生成缩略图 } location ~* /(\d+)_(\d+)x(\d+)\.(jpg)$ { if ( -e $document_root/$1.$4 ) { # 判断原图是否存在 rewrite /(\d+)_(\d+)x(\d+)\.(jpg)$ /$1.$4?h=$2&w=$3 last; } return 404; }
例如图片:
http://test.ttlsa.com/123_100x10.jpg
一、 首先判断是否存在原图123.jpg,不存在直接返回404(若是原图都不存在,还生成缩略图干啥,对吧)
二、 跳转到http://tset.ttlsa.com/123.jpg?h=100&w=10,将参数高h和宽10带到url中。
三、 Image_filter resize指令根据h和w参数生成相应缩略图。
备注:长宽取小,例如原图是100*10,你传入的是10*2,那么他会给你生成10*1的图片.java
生成缩略图只是image_filter功能中的一个,它一共支持4种参数:
test:返回是否真的是图片
size:返回图片长短尺寸,返回json格式数据
corp:截取图片的一部分,从左上角开始截取,尺寸写小了,图片会被剪切
resize:缩放图片,等比例缩放nginx
nginx生成缩略图优缺点
优势:
一、 根据传入参数便可生成各类比例图片
二、 不占用任何硬盘空间程序员
缺点:
一、消耗CPU,访问量大将会给服务器带来极大的负担.json
几点建议:
一、 生成缩略是个消耗cpu的操做,若是访问量比较大的站点,最好考虑使用程序生成缩略图到硬盘上,或者在前端加上cache或者使用CDN。服务器
转载请注明出处:http://www.ttlsa.com/html/1612.htmlapp