Fastdfs与nginx进行压缩图片比率_nginx

在此先把前面自己做的那个功能在此分享下,是一个模仿淘宝的,希望大神们有什么想法可以不吝赐教:

自己是通过前面的参考配置lua与nginx的结合使用,利用脚本语言lua的强大特性和nginx的特性来实现这个功能,在nginx.conf的配置文件中加入如下代码:

server {

  listen  22222;

  server_name localhost;

  # server_name somename alias another.alias;

  location /images/{

  alias /root/images;

  set $image_root /root;

  set $file $image_root$uri;

  content_by_lua '

    ngx.header.content_type = "text/plain";

    ngx.say(ngx.var.file);

   ';

  }

  location /lua{

   set $test "hello, world.";

   content_by_lua '

     ngx.header.content_type = "text/plain";

     ngx.say(ngx.var.test);

   ';

  }

  location /group1/M00 {

   alias /usr/local/servers/data/fdfs/data;

   set $image_root "/usr/local/servers/data/fdfs/data";

   # alias /root/images;

   # set $image_root "/root/images";

   if ( $uri ~ "/([a-zA-Z0-9]+)/([a-zA-Z0-9]+)/([a-zA-Z0-9]+)/([a-zA-Z0-9]+)/(.*)" ) {

     set $image_dir "$image_root/$3/$4";

     set $image_name "$5";

     set $file "$image_dir/$image_name";

    }

  # content_by_lua '

   #  ngx.header.content_type = "text/plain";

   #  ngx.say(ngx.var.image_dir);

   #  ngx.say(ngx.var.image_name);

   #  ngx.say(ngx.var.file);

   # ';

    if ( !-f $file ) {

    # 关闭lua代码缓存,方便调试lua脚本

    #lua_code_cache off;

    content_by_lua_file "/usr/local/servers/lua/convert.lua";

    }

     ngx_fastdfs_module;

  }

  # location ~ /group[1-3]/M00{

   # root /usr/local/servers/data/fdfs/data; #/fdfs/storage/data;

   # ngx_fastdfs_module;

   # }

  }

这里面利用了nginx的正则表达式,正则表达式是相当强悍的,可以得到你需要访问的uri的值。

然后再convert.lua中写入如下代码:

local area = nil

local originalUri = ngx.var.uri;

local originalFile = ngx.var.file;

local index = string.find(ngx.var.uri, "([0-9]+)x([0-9]+)");

if index then

 originalUri = string.sub(ngx.var.uri, 0, index-2);

 area = string.sub(ngx.var.uri, index);

 index1 = string.find(area, "([.])");

 area1 = string.sub(area, 0, index1-1);

 local index2 = string.find(originalFile, "([0-9]+)x([0-9]+)");

 originalFile1 = string.sub(originalFile, 0, index2-2)

end

local image_sizes = {"80x80", "800x600", "40x40", "60x60"};

function table.contains(table, element)

 for _, value in pairs(table) do

  if value == element then

   return true

  end

 end

 return false

end

if table.contains(image_sizes, area1) then

 local command = "/usr/bin/gm convert " .. originalFile1 .. " -thumbnail " .. area1 .. " -background gray -gravity center -extent " .. area1 .. " " .. ngx.var.file;

 os.execute(command);

end;

~差不多这样就可以实现功能了,通过访问可以实现比率压缩,因为在上班时间暂时就这么写下了,目前的一个工作还有很多功能需要实现,如有看不懂的可以留言,大神们可以指教,谢谢!

      参考:http://www.v2ex.com/t/113845

       http://blog.sina.com.cn/openresty

       http://write.blog.csdn.net/postedit

        https://github.com/azurewang/lua-resty-fastdfs/blob/master/lib/resty/fastdfs/storage.lua

http://www.jb51.net/sys/CentOS/55070.htm

http://wiki.nginx.org/HttpLuaModule

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索nginx
, fastdfs
压缩图片
fastdfs nginx 图片、fastdfs图片压缩、nginx 图片压缩、nginx 图片压缩模块、nginx gzip 图片压缩,以便于您获取更多的相关知识。

时间: 2024-10-05 21:57:42

Fastdfs与nginx进行压缩图片比率_nginx的相关文章

Linux环境下nginx搭建简易图片服务器_nginx

主要使用Nginx和vsftpd. 安装方面可以直接从nginx官网上下载,或者... 复制代码 代码如下: yum install nginx  如果没有yum源则需要自行添加再进行install. 复制代码 代码如下: yum install wget wget http://www.atomicorp.com/installers/atomic  sh ./atomic  yum check update  如果是从官网上下载的则进行如下操作: 复制代码 代码如下: [root@admin

Nginx 开启gzip压缩(图片,文件,css)

1.Vim打开Nginx配置文件 vim /usr/local/nginx/conf/nginx.conf 2.找到如下一段,进行修改 gzip on; gzip_min_length 1k; gzip_buffers 4 16k; #gzip_http_version 1.0; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml text/javascript ap

详解Nginx服务器的配置中开启文件Gzip压缩的方法_nginx

gzip(GNU- ZIP)是一种压缩技术.经过gzip压缩后页面大小可以变为原来的30%甚至更小,这样,用户浏览页面的时候速度会块得多.gzip的压缩页面需要浏览 器和服务器双方都支持,实际上就是服务器端压缩,传到浏览器后浏览器解压并解析.浏览器那里不需要我们担心,因为目前的巨大多数浏览器都支持解析gzip 过的页面. Nginx的压缩输出有一组gzip压缩指令来实现.相关指令位于http{-.}两个大括号之间. 下面大致讲一下配置开启gzip压缩的方法: 1.Vim打开Nginx配置文件 v

Nginx中的Gzip压缩配置介绍_nginx

随着nginx的发展,越来越多的网站使用nginx,因此nginx的优化变得越来越重要,今天我们来看看nginx的gzip压缩到底是怎么压缩的呢? gzip(GNU- ZIP)是一种压缩技术.经过gzip压缩后页面大小可以变为原来的30%甚至更小,这样,用户浏览页面的时候速度会块得多.gzip的压缩页面需要浏览 器和服务器双方都支持,实际上就是服务器端压缩,传到浏览器后浏览器解压并解析.浏览器那里不需要我们担心,因为目前的巨大多数浏览器都支持解析gzip 过的页面. Nginx的压缩输出有一组g

Node.js站点使用Nginx作反向代理时配置GZip压缩的教程_nginx

node.js 开发的站点,如果你也是用了nginx实现反向代理. 那么在服务端可以轻松实现 gzip 压缩,让站点浏览更顺畅. 前提条件: node.js + nginx 反向代理. node.js 需要做的工作: express 4.0以下版本: app.use(express.compress()); //主要是这句 app.use(express.json()); app.use(express.urlencoded()); app.use(express.bodyParser());

nginx配置访问图片路径以及html静态页面的调取方法_nginx

给大家讲一个快速配置nginx访问图片地址,以及访问html静态页面的配置. 1.实验环境 首先随便某个路径下创建相应的目录.如图下 2.在里面放自定义的html或者图片. 3.nginx配置 user root; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events {

如何用图片压缩工具ImageOptimizer压缩图片

现在的大容量存储卡.移动硬盘已经使我们可以避免照片拍摄数量的限制.但作为非出版用途,在网上和大家交流的照片,需要尺寸尽量小,但质量却不能很差.过大的图片放在网页上会减缓访问者的下载速度,影响浏览.此时,我们就有必要使用图像压缩处理软件给图像减减肥,去除其中的冗余信息. Image Optimizer是图片优化工具中的佼佼者.它与JPEG Optimizer是同一家公司出品的软件,后者是针对JPEG格式图像的,而Image Optimizer可以对JPG.GIF.PNG.BMP.TIF 等图像文件

为什么fastdfs开启防盗链,图片有效,视频不需要token仍然可以播放或下载?

问题描述 为什么fastdfs开启防盗链,图片有效,视频不需要token仍然可以播放或下载? if use token to anti-steal default value is false (0) http.anti_steal.check_token=true token TTL (time to live), seconds default value is 600 http.anti_steal.token_ttl=900 secret key to generate anti-ste

java压缩图片问题,白色背景图片

问题描述 java压缩图片问题,白色背景图片 原图:压缩后的图:就是背景是白色的图片(jpg格式),压缩后都会变颜色.不是白色背景的上传没问题.求解答 // 压缩代码 File file = new File(inputFilePath); if (!file.exists()) { SysUtil.printDebugLog(""=======源图片不存在====="" + inputFilePath); return false; } Image img = I