以下是7点经验结论和5个参考资料

1.Nginx单独配置缩略图与Nginx和Fastdfs模块整合,配置是不一样的。

非整合模式的配置,类似这样的:
  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;
}

整合模式的配置,类似这样的:
  location ~ group1/M00/(.+)\.?(.+){
             alias /home/fastdata/data;
             ngx_fastdfs_module;
        }

Fastdfs的URL比较特殊,group1/M00,自己的实践体会是,不能随便改名字。

2.缩略图的配置其实很简单,难在缩略图和非缩略图共存。
  location ~ group1/M00/(.+)\.?(.+){
             alias /home/fastdata/data;
             ngx_fastdfs_module;
image_filter resize 10 10;
   }
   
3.亲自实践的不可行的方案,或者说最终搞不定的方案。
访问原图的URL
http://ip/a.img

访问缩略图的URL
http://ip/a.img?w=10&h=10

数据库存的是“a.img”,我希望如果想要获得缩略图,直接在后面增加url参数,w和h。
因此,我尝试的Nginx配置:

location  ~ /group1/a/M00(.*).jpg {
 49          root /home/fdfsdata/data;
 50          ngx_fastdfs_module;
 60          if ($w != ""){
 61           # rewrite /group1/M00 /image/resize$request_uri;
 62          }
 63       }
 64 
 69      
 91      location ~ /image/resize/group1/M00 {
 92         #set $h 100;   
 93         #set $w $arg_w;  
 94         #rewrite ^/image/resize http://baidu.com?$request_uri-$document_uri-$query_string-$uri;
 95 #        rewrite /image/resize/group1/M00 http://baidu.com?request_uri=$request_uri;
 96        root /home/fdfsdata/data;
 97          ngx_fastdfs_module;
 98         #image_filter test;
 99         #image_filter size;
100        # image_filter off;
101         image_filter resize 100 100;
102      }

以上只代表了思路,不是“原貌”。
大致的意思,就是
a.拦截图片,如果宽度w不为空,就rewrite重定向到“/image/resize/group1/M00”,
让第2个配置,执行 image_filter resize 100 100,获得缩略图。
b.如果w为空,直接获得原图。

总是报400,415之类的错误。
最初为了获得,重定向的url,试了很多方法。
rewrite /group1/M00 /image/resize$request_uri;
最后探索出,上述方式是比较好的。

但是,最后发现Fastdfs的路径,不能随便改,修改了,容易出现400、404,或415.

为了探索url中的一些参数,比如$1,$request_uri等,网上看了一些资料,知道了大致的意思。
在参考别人的之前,我想到了一种方法,
rewrite ^/image/resize http://baidu.com?$request_uri-$document_uri-$query_string-$uri;
重定向到一个明确的页面,比如百度的首页,把参数放到?之后,然后在浏览器的地址栏就可以看到了。

尝试使用了echo命令,Nginx不可识别。
网上找到了,Nginx有echo模块,大概是说,安装了echo模块,方便在Nginx用echo输出变量,方便调试。

4.if ($w != "")。
Nginx的if语句,左右貌似需要空格~
坑~

5.nginx之location配置
http://blog.csdn.net/hellochenlian/article/details/44655547
  值得好好学习下
  没有系统学习Nginx,感觉很多时候,比较吃亏。
  我打算2016年认真学习Nginx,买本好书,系统地学习下。
  一点点地学,很累,记不住~
  
6.其实,不一定要非要用Nginx的image_filter模块实现缩略图。
也可以用程序控制,比如上传图片的时候,实时生成多种尺寸的图片,存到Fastdfs。
优点和缺点,还是经典的“时间”和“空间”问题。

7.最终可行Nginx配置
location ~ /group1/M00/(.*)_([0-9]+)x([0-9]+)\.jpg{
 71          root /home/fdfsdata/data;
 72          ngx_fastdfs_module;
 73          set $w $2;
 74          set $h $3;
 75  #           if ($h != "0") {
 76                #      rewrite /group1/M00/(.+)_(\d+)x(\d+)\.(jpg|gif|png)$ /group1/M00/$1.$4 last;
 77 #                rewrite group1/M00(.+)_(\d+)x(\d+)\.(jpg|gif|png)$ group1/M00$1.$4 break;
 78   #          } 
 79             if ($w != "0") {
 80                    rewrite /group1/M00/(.+)_(\d+)x(\d+)\.(jpg|gif|png)$ /group1/M00/$1.$4 break;
 81             }
 82             image_filter resize $w $h;
 83             image_filter_buffer 2M;
 84       }
 85 
 86    location ~ group1/M00/(.+)\.?(.+){
 87            alias /home/fastdata/data;
 88            ngx_fastdfs_module;
 89    }

需要注意,用的小写的“x”。
 
 访问举例:
 获得原图
 http://42.96.184.84:8080/group1/M00/00/00/KmC4VFY7GsiATWTJAAA3vrrOOWM943.jpg

缩略图1

http://42.96.184.84:8080/group1/M00/00/00/KmC4VFY7GsiATWTJAAA3vrrOOWM943_100x30.jpg

缩略图2
 http://42.96.184.84:8080/group1/M00/00/00/KmC4VFY7GsiATWTJAAA3vrrOOWM943_150x50.jpg

没有搞成功的,最初尝试的方案
 http://42.96.184.84:8080/group1/M00/00/00/KmC4VFY7GsiATWTJAAA3vrrOOWM943.jpg?w=10&h=10
 
 数据库存的URL:group1/M00/00/00/KmC4VFY7GsiATWTJAAA3vrrOOWM943.jpg
 如果要按照KmC4VFY7GsiATWTJAAA3vrrOOWM943_150x50.jpg展示,需要获得文件名,修改,加上指定的宽度和高度
 _150x50.
 
8.参考资料
    FastDFS组合nginx的http_image_filter_module建立的图片服务器(最关键,可行方法,在帖子的最后面)
http://bbs.chinaunix.net/thread-4058548-1-1.html

nginx生成缩略图配置 – ttlsa教程系列之nginx(参考)
    http://www.ttlsa.com/nginx/nginx-modules-image_filter_module/

Nginx国人开发缩略图模块(ngx_image_thumb)(参考,和上面的类似)
http://www.ttlsa.com/nginx/nginx-modules-ngx_image_thumb/

Nginx图片剪裁模块探究 http_image_filter_module
    http://cwtea.blog.51cto.com/4500217/1333142

nginx之location配置
http://blog.csdn.net/hellochenlian/article/details/44655547

Nginx缩略图和Fastdfs整合以及image_filter配置,7点经验结论和5个参考资料的更多相关文章

  1. FastDFS整合nginx后,nginx一直报错

    FastDFS整合nginx后,nginx一直报错: 报错内容: [2018-06-11 09:41:21] ERROR - file: ../common/fdfs_http_shared.c, l ...

  2. FastDFS整合Nginx

    浏览器访问FastDFS存储的图片需要通过Nginx访问 需要安装fastdfs-nginx-module.Nginx 安装fastdfs-nginx-module模块 (1)将fastdfs-ngi ...

  3. 分布式文件系统 - FastDFS 在 CentOS 下配置安装部署

    少啰嗦,直接装 看过上一篇分布式文件系统 - FastDFS 简单了解一下的朋友应该知道,本次安装是使用目前余庆老师开源的最新 V5.05 版本,是余庆老师放在 Github 上的,和目前你能在网络上 ...

  4. FastDFS 集群 安装 配置

    这篇文章介绍如何搭建FastDFS 集群 FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负载均衡的 ...

  5. nginx于tomcat项目整合(拆分静态文件)

    1.在很多时候我们在网站上应用的时候都会用到nginx,由于我们是java开发者,不可避免的是我们需要在我们的tomcat的工程中应用到nginx,这里的应用可以是请求转发,负载均衡,反向代理,配置虚 ...

  6. Nginx + Tomcat Windows下的负载均衡配置

     Nginx + Tomcat Windows下的负载均衡配置 一.为什么需要对Tomcat服务器做负载均衡?    Tomcat服务器作为一个Web服务器,其并发数在300-500之间,如果超过50 ...

  7. nginx下目录浏览及其验证功能配置记录

    工作中常常有写不能有网页下载东西的需求,在Apache下搭建完成后直接导入文件即可达到下载/显示文件的效果;而Nginx的目录列表功能默认是关闭的,如果需要打开Nginx的目录列表功能,需要手动配置, ...

  8. Flask+Nginx+uWSGI在Ubuntu服务器上的配置

    Flask+Nginx+uWSGI在Ubuntu服务器上的配置 Step1 安装系统环境 Ubuntu服务器选择是阿里云的ECS服务,ECS提供单独的内存\CPU\带宽\存储规格可以选择,并且提供合适 ...

  9. nginx 反向代理 与 Apache backend的配置联合配置

    nginx 反向代理 与 Apache backend的配置联合配置: 说明: nginx 将http映射到Apache上的特定子目录. 配置方法步骤: 1.  设置域名, 子域名映射到指定服务器ip ...

随机推荐

  1. android获取自己定义控件位置坐标,屏幕尺寸,标题栏,状态栏高度

    android获取自己定义控件位置坐标,屏幕尺寸,标题栏,状态栏高度 1.获取自己定义控件height 在本Activity中获取当前Activity中控件的height: Button button ...

  2. iOS开发 - 二维码的生成与读取

    二维码的生成 从iOS7開始集成了二维码的生成和读取功能 此前被广泛使用的zbarsdk眼下不支持64位处理器 生成二维码的步骤: 导入CoreImage框架 通过滤镜CIFilter生成二维码 二维 ...

  3. 关于DPM(Deformable Part Model)算法中模型可视化的解释

    搭建了自己的博客平台,本文地址:http://masikkk.com/blog/DPM-model-visualization/ DPM源代码(voc-release)中的模型可视化做的还算相当炫酷的 ...

  4. WET Dilutes Performance Bottlenecks

    WET Dilutes Performance Bottlenecks Kirk Pepperdine THE IMPORTANCE OF THE DRY PRINCIPLE (Don't Repea ...

  5. 有关 IE11

    IE10/IE11 中 99% 的 CSS3 属性不需要写 -ms- 前缀: IE9/IE10/IE11 默认开启 GPU 加速,效果比同期 Chrome 版本(如 35)流畅: IE11 的字体渲染 ...

  6. iOS 集成Protobuf,转换proto文件

    原文地址:http://blog.csdn.net/hyq4412/article/details/54891038 附加Homebrew安装地址:https://brew.sh/index_zh-c ...

  7. 用Electron开发企业网盘(一)--通信

    效果展示 项目背景: 由于浏览器的限制,web批量下载体验不好以及无法下载文件夹.采用Electron技术,通过js开发PC应用程序,着力解决批量下载.断点续传.文件夹下载等问题.配合网页版网盘使用, ...

  8. [转载]CentOS 7虚拟机下设置固定IP详解

    在 复制 他人作品之前,是因为我再此“跌倒”过一次,虽然原主说是永久地址,但是地址失效 不可避免.所以就原封不动的copy了过来,我自己也是按照他的一步一步配置的,我成功了,相信你们也会成功. 如果不 ...

  9. CSU 1506 Double Shortest Paths

    1506: Double Shortest Paths Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 49  Solved: 5 Description ...

  10. 137 - ZOJ Monthly, November 2014 - J Poker Face

    Poker Face Time Limit: 2 Seconds      Memory Limit: 65536 KB As is known to all, coders are lack of ...