Nginx 实时生成缩略图

缩略图的生成有多种方式,如使用java生成缩略图,也可以使用nginx+lua实现,下面我们讲解一下使用nginx自带的模块生成缩略图,模块:-with-http_image_filter_module。

一、安装nginx

下载地址:http://nginx.org/download/

1.使用root安装依赖

yum -y install pcre pcre-devel zlib zlib-devel openssl openssl-devel gd gd-devel

2.下载nginx,安装

wget http://nginx.org/download/nginx-1.7.9.tar.gz

mkdir nginx

tar -zxvf nginx-1.7.9.tar.gz

cd nginx-1.7.9

./configure  --prefix=/home/slim/nginx --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_image_filter_module

make 

make install

二、配置

生成缩略是个消耗cpu的操作,如果访问量比较大的站点,最好考虑使用程序生成缩略图到硬盘上,或者在前端加上cache或者使用CDN。所以下面我们配置将生成的缩略图保存到硬盘供下次访问

创建图片目录:mkdir img_site

location ~* ^/resize {
                root /home/slim/img_site/$server_name;
                set $width 150;
                set $height 100;
                set $dimens "";

                if ($uri ~* "^/resize_(\d+)x(\d+)/(.*)" ) {
                                set $width $1;
                                set $height $2;
                                set $image_path $3;
                                set $demins "_$1x$2";
                }

                if ($uri ~* "^/resize/(.*)" ) {
                                set $image_path $1;
                }

                set $image_uri image_resize/$image_path?width=$width&height=$height;

                if (!-f $request_filename) {
                                proxy_pass http://192.168.36.54:8080/$image_uri;
                                break;
                }
                proxy_store /home/slim/img_site/$server_name/resize$demins/$image_path;
                proxy_store_access user:rw group:rw all:r;
                proxy_set_header Host $host;
                expires      30d;
                access_log off;
        }
        location /image_resize {
                alias /home/slim/img_site/$server_name;#原图目录
                image_filter resize $arg_width $arg_height; #指令根据height和width参数生成相应缩略图
                image_filter_jpeg_quality 75;
                image_filter_buffer 10m;
                access_log off;
        }
生成缩略图只是image_filter功能中的一个,它一共支持4种参数:

test:返回是否真的是图片
size:返回图片长短尺寸,返回json格式数据
corp:截取图片的一部分,从左上角开始截取,尺寸写小了,图片会被剪切
resize:缩放图片,等比例缩放

Nginx 实时生成缩略图_第1张图片
生成缩略图流程如下:
1、原图在/home/slim/img_site/localhost/images/a.png。我需要一份100×100的缩略图。
2、请求http://192.168.36.54:8080/resize_100x100/image/1.jpg.
3、这个请求进入了location ~* ^/resize,接着判断image_path这个目录下是否存在这张图片,如果存在直接放回给用户,
4、不存在那么跳转到http://192.168.36.54:8080/image_resize/image/1.jpg?width=100&height=100;
5、location /image_resize根据传入的width和height执行缩略功能,并且设置图像质量为75
6、接着生成文件/home/slim/img_site/localhost/resize_100x100/images/a.png缩略图到硬盘上

三、启动,测试

在/home/slim/img_site/localhost/images下新建图片目录images,copy几张图片过来。

启动nginx:

./nginx/sbin/nginx

访问http://192.168.36.54:8080/resize_100x100/images/a.png试试。


参考文章

1.Nginx图片剪裁模块探究 http_image_filter_module

你可能感兴趣的:(nginx)