`

OpenResty(Nginx)+Lua+GraphicsMagick实现缩略图功能

 
阅读更多

OpenResty(Nginx)+Lua+GraphicsMagick实现缩略图功能

 

一、背景说明

大多数网站基本都涉及到图片缩略图的处理,比如新闻配图、电商商品图等,特别是电商类网站,每个商品图对应多个不同尺寸的缩略图,用于不同的页面。

 

初期访问量少时,处理流程一般由web程序在上传成功后,同时生成相应缩略图。这种方式在访问量小,单机部署时没有问题。当访问量逐渐加大,服务器由单台变为多台时,这种方式扩展性较差。

 

以下有几种方案可以解决这个问题:

1、使用七牛、又拍云提供的云存储及数据处理服务,解决图片的处理、存储、多节点访问速度的问题,这种方式优点是方案成熟,相应的有一定费用和开发工作,另外有一些小概率的风险,比如云服务挂掉影响本站访问。

2、使用第三方的图片处理程序,比如zimg,点击查看使用手册,@招牌疯子开发。zimg的性能和扩展性不错,文档也很完善,会继续保持关注。

3、自己造轮子,根据自身业务,将生成缩略图功能独立出来,与web程序解耦。

 

我们采用的是第三种方案,参考了网友的基础代码,利用OpenResty(Nginx)+Lua+GraphicsMagick实现缩略图功能,图片上传及删除还是由web程序处理,缩略图由单独模块完成。目前可实现配置路径及缩略尺寸,无图片时显示默认图片,支持多种缩放方式等,后续可基于GraphicsMagick实现更多功能

 

 

二、相关规范

1、文件夹规划

 

img.51ajax.com
|-- avatars
|   `-- 001
|       `-- 001.jpg
|-- default
|   `-- notfound.jpg
|-- photos
|   `-- 001
|       `-- 001.jpg
`-- thumbnail
    `-- photos
        `-- 001
            |-- 001_100x100.jpg
            |-- 001_140x140.jpg
            |-- 001_250x250.jpg
            |-- 001_300x300.jpg
            |-- 001_350x350.jpg
            |-- 001_50x50.jpg
            `-- abc_50x50.jpg

 

 

其中img.51ajax.com为图片站点根目录,avatars和photos目录是原图目录,可根据目录设置不同的缩略图尺寸,default文件夹的notfound.jpg文件是在未找到原图时的默认图片,thumbnail文件夹用来存放缩略图,可定时清理。

 

2、链接地址

原图访问地址:http://img.51ajax.com/photos/001/001.jpg

缩略图访问地址:http://img.51ajax.com/photos/001/001_100x100.jpg,(请勿加thumbnail,这个是因为我们原来的原图和缩略图在同一个目录,后来将缩略图单独放了一个文件夹)

 

3、访问流程

首先判断缩略图是否存在,如存在则直接显示缩略图;

如不存在则按以下流程处理:

1).判断原图是否存在,如原图不存在则进入下一步;如存在则跳至4

2).判断是否显示默认图片,如不显示则404退出;如显示则进入下一步

3).判断是否存在默认图片,如不存在则404退出;如存在则将默认图片代替原始图片,进入下一步;

4).判断缩略图链接与规则是否匹配,如不匹配,则404退出;如匹配跳至5

5).拼接graphicsmagick命令,生成并显示缩略图

 

三、安装OpenResty

yum install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel

 

1、关于OpenResty(http://openresty.org/cn/)

 

OpenResty (也称为 ngx_openresty)是一个全功能的 Web 应用服务器,它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项。

OpenResty 通过汇聚各种设计精良的 Nginx 模块,

从而将 Nginx 有效的变成一个强大的 Web 应用服务器,

这样, Web 开发人员可以使用 Lua 脚本语言调动 Nginx 支持的各种C以及Lua 模块,

快速构造出足以胜任 10K+ 并发连接响应的超高性能Web 应用系统。更多

 

2、安装OpenResty

注:drizzle-nginx-module模块和nginx-http-concat模块非必选项,各位可按需安装

 

#安装依赖lib
yum install readline-devel pcre-devel openssl-devel

#创建安装文件目录
mkdir -p /usr/local/src/nginx
cd /usr/local/src/nginx
 
#安装drizzle模块(访问mysql数据库模块,非必需,建议安装)
wget http://agentzh.org/misc/nginx/drizzle7-2011.07.21.tar.gz 
tar zxvf drizzle7-2011.07.21.tar.gz 
cd drizzle7-2011.07.21
./configure --without-server
make libdrizzle-1.0
make install-libdrizzle-1.0
cd ..
 
#下载openresty 
wget http://openresty.org/download/ngx_openresty-1.4.2.7.tar.gz
tar zxvf ngx_openresty-1.4.2.7.tar.gz
 
#下载nginx-http-concat(合并静态文件请求模块,非必需,建议安装)
wget https://github.com/alibaba/nginx-http-concat/archive/master.zip
unzip master
mv nginx-http-concat-master/ ngx_openresty-1.4.2.7/bundle/nginx-http-concat
 
#安装openresty 
cd ngx_openresty-1.4.2.7
./configure --with-luajit --with-http_drizzle_module --with-http_iconv_module --with-ld-opt="-Wl,-rpath,/usr/local/lib"  --with-http_stub_status_module --with-http_ssl_module --with-http_sub_module --add-module=./bundle/nginx-http-concat/
gmake
gmake install

 

 

 

3、将OpenResty(Nginx)加入自启动

 

vi /etc/rc.d/init.d/nginx
文件内容如下

#! /bin/sh
# chkconfig: 2345 55 25
# Description: Startup script for nginx webserver on Debian. Place in /etc/init.d and
# run 'update-rc.d -f nginx defaults', or use the appropriate command on your
# distro. For CentOS/Redhat run: 'chkconfig --add nginx'
 
### BEGIN INIT INFO
# Provides:          nginx
# Required-Start:    $all
# Required-Stop:     $all
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: starts the nginx web server
# Description:       starts nginx using start-stop-daemon
### END INIT INFO
 
 
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DESC="nginx daemon"
NAME=nginx
DAEMON=/usr/local/openresty/nginx/sbin/$NAME
CONFIGFILE=/usr/local/openresty/nginx/conf/$NAME.conf
PIDFILE=/usr/local/openresty/nginx/logs/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME
 
set -e
[ -x "$DAEMON" ] || exit 0
 
do_start() {
 $DAEMON -c $CONFIGFILE || echo -n "nginx already running"
}
 
do_stop() {
 kill -INT `cat $PIDFILE` || echo -n "nginx not running"
}
 
do_reload() {
 kill -HUP `cat $PIDFILE` || echo -n "nginx can't reload"
}
 
case "$1" in
 start)
 echo -n "Starting $DESC: $NAME"
 do_start
 echo "."
 ;;
 stop)
 echo -n "Stopping $DESC: $NAME"
 do_stop
 echo "."
 ;;
 reload|graceful)
 echo -n "Reloading $DESC configuration..."
 do_reload
 echo "."
 ;;
 restart)
 echo -n "Restarting $DESC: $NAME"
 do_stop
 do_start
 echo "."
 ;;
 *)
 echo "Usage: $SCRIPTNAME {start|stop|reload|restart}" >&2
 exit 3
 ;;
esac
 
exit 0


 

 

把nginx加入chkconfig,并设置开机启动

chkconfig --add nginx

chkconfig nginx on

 

启动、停止、查看状态

service nginx start

service nginx stop

service nginx status

 

 

四、安装GraphicsMagick

1、安装

 

#创建安装目录 
mkdir -p /usr/local/src/graphicsmagick
cd /usr/local/src/graphicsmagick
 
#下载graphicsmagick
wget ftp://ftp.graphicsmagick.org/pub/GraphicsMagick/1.3/GraphicsMagick-1.3.16.tar.gz
tar zxvf GraphicsMagick-1.3.16.tar.gz 
#下载libjpeg
wget  ftp://ftp.pl.freebsd.org/vol/rzm1/GraphicsMagick/delegates/libjpeg-6b.tar.gz
rpm -qa | grep libjpeg
rpm -qa | grep libjpeg | xargs rpm -e --nodeps --allmatches
tar zxvf libjpeg-6b.tar.gz 
cd libjpeg-6b
./configure
make
make install
ln -s /usr/local/lib/libjpeg* /lib/
ln -s /usr/local/lib/libjpeg* /lib64/
cd ..
 
#安装libpng 
rpm -qa | grep libpng
rpm -qa | grep libpng | xargs rpm -e --nodeps --allmatches 
wget ftp://ftp.pl.freebsd.org/vol/rzm1/GraphicsMagick/delegates/libpng-1.2.49.tar.gz
tar zxvf libpng-1.2.49.tar.gz 
cd libpng-1.2.49
./configure
make
make install
ln -s /usr/local/lib/libpng* /lib/
ln -s /usr/local/lib/libpng* /lib64/
cd ../
 
#安装freetype 
wget ftp://ftp.pl.freebsd.org/vol/rzm1/GraphicsMagick/delegates/freetype-2.4.10.tar.gz
tar zxvf freetype-2.4.10.tar.gz 
cd freetype-2.4.10
./configure
make install
ln -s /usr/local/lib/freetype* /lib/
ln -s /usr/local/lib/freetype* /lib64/
cd ..
 
#安装GraphicsMagick
cd GraphicsMagick-1.3.16
./configure --prefix=/usr/local/graphicsmagick-1.3.16
make
make install
 
#编辑profile文件
vi /etc/profile
 
#末尾增加以下内容
export GMAGICK_HOME="/usr/local/graphicsmagick-1.3.16" 
export PATH="$GMAGICK_HOME/bin:$PATH" 
LD_LIBRARY_PATH=$GMAGICK_HOME/lib:$LD_LIBRARY_PATH 
export LD_LIBRARY_PATH  

#保存退出,运行以下命令立即生效配置

source /etc/profile

 

 

2、用法

 原始图片是input.jpg,尺寸:160×120

 

1)只缩小不放大

gm convert input.jpg -resize "500x500>" output_1.jpg

 加了>,表示只有当图片的宽与高,大于给定的宽与高时,才进行“缩小”操作。

生成的图片大小是:160×120,未进行操作

如果不加>,会导致图片被比等放大。

 

2)等比缩图 (缺点:产生白边)

gm convert input.jpg -thumbnail "100x100" output_1.jpg

 生成的图片大小是:100×75

 

3)非等比缩图,按给定的参数缩图(缺点:长宽比会变化)

 

gm convert input.jpg -thumbnail "100x100!" output_2.jpg

生成的图片大小是:100×100

 

4)裁剪后保证等比缩图 (缺点:裁剪了图片的一部分)

gm convert input.jpg -thumbnail "100x100^" -gravity center -extent 100x100 output_3.jpg

生成的图片大小是:100×100,还保证了比例。不过图片经过了裁剪,剪了图片左右两边才达到1:1

 

5)填充后保证等比缩图 (缺点:要填充颜色,和第一种方法基本一样)

gm convert input.jpg -thumbnail "100x100" -background gray -gravity center -extent 100x100 output_4.jpg

生成的图片大小是:100×100,还保证了比例,同时没有对图片进行任何裁剪,缺失的部分按指定颜色进行填充。

 

6)裁剪、填充相结合 (缺点:最差的方法)

 

gm convert input.jpg -thumbnail "10000@ -background gray -gravity center -extent 100x100 output_5.jpg

生成的图片大小是:100×100,这次保证了大小和比例,其中的10000就是100×100的乘积,同时在填充和裁剪之间做了一个平衡。

 

7)位深度32 转为24

IE6,7,8不支持显示“位深度32”的图片,但IE9、火狐、谷歌浏览器就可以显示。

使用GM,把“位深度32”的图片转换为“位深度24”的图片

输入图片zzz.jpg就是“位深度32”的图片,输出图片 zzz_out.jpg就是“位深度24”的图片

gm convert -resize 100x100 -colorspace RGB zzz.jpg zzz_out.jpg

 转完后,图片的颜色会有轻微变化。

 

更多请参考:http://elf8848.iteye.com/blog/382528

 

五、相关配置及脚本

1、Nginx配置文件

 

http {
    
    lua_package_path '/usr/local/openresty/nginx/lua/?.lua;;';
    
    server {
            listen       80;
            server_name  img.51ajax.com;
            root  /home/wwwroot/img.51ajax.com;
            
            #配置此项,使/thumbnail目录下的图片请求不再经过缩略图模块
            location ^~ /thumbnail/ {
     
            }
            
            #对类似_100x100.gif/jpg/png/jpeg进行缩略图处理
            location ~* _([0-9]+)x([0-9]+)\.(gif|jpg|png|jpeg)$ {     
                    #站点根目录
                    root  /home/wwwroot/img.51ajax.com;      
                    #图片目录
                    set $image_root /home/wwwroot/img.51ajax.com;             
                    #缩略图存放目录
                    set $thumbnail_root /home/wwwroot/img.51ajax.com/thumbnail;     
                    #如果缩略图文件存在,直接返回
                    set $file $thumbnail_root$uri;
                    if (-f $file) {
                            rewrite ^/(.*)$ /thumbnail/$1 last;
                    }
                    #如果缩略图文件不存在,则应用缩略图模块处理
                    if (!-f $file) {
                            rewrite_by_lua_file /usr/local/openresty/nginx/lua/thumbnail.lua;
                    }
            }
     
            location ~ / {
                    expires 1d;
                    index  index.html;
            }
}

 

2、Lua脚本

/usr/local/openresty/nginx/lua/thumbnail.lua

 

-- nginx thumbnail module 
-- last update : 2014/8/1
-- version     : 0.4
 
local c  = require 'config'
 
--[[
    uri               :链接地址,如/goods/0007/541/001_328x328.jpg
    ngx_img_root      :图片根目录
    ngx_thumbnail_root:缩略图根目录
    img_width         :缩略图宽度 
    img_width         :缩略图高度
    img_size          :缩略图宽x高
    img_crop_type     :缩略图裁剪类型
]]
local uri = ngx.var.uri;
local ngx_img_root = ngx.var.image_root;
local ngx_thumbnail_root = ngx.var.thumbnail_root;
local img_width,img_height,img_size,img_crop_type = 0;
 
--[[
    日志函数
    log_level: 默认为ngx.NOTICE
    取值范围:ngx.STDERR , ngx.EMERG , ngx.ALERT , ngx.CRIT , ngx.ERR , ngx.WARN , ngx.NOTICE , ngx.INFO , ngx.DEBUG
    请配合nginx.conf中error_log的日志级别使用
]]
function lua_log(msg,log_level)
    local lua_log_level = ngx.NOTICE
    if (log_level) then
        lua_log_level = log_level
    end
    if(c.enabled_log) then 
        ngx.log(lua_log_level,msg) 
    end
end
 
--    匹配链接对应缩略图规则
function table.contains(table,element)
    for _, value in pairs(c.cfg) do
        local dir = value['dir'];
        local sizes = value['sizes'];
        _,_,img_width,img_height = string.find(uri,''..dir..'+.*_([0-9]+)x([0-9]+)');
        if(img_width and img_height ) then
            img_size = img_width..'x'..img_height;
            for _, value in pairs(sizes) do
                if (img_size == value) then
                    img_crop_type=1;
                    return true;
                elseif (img_size..'_' == value) then
                    img_crop_type=2;
                    return true;                    
                elseif (img_size..'!' == value) then
                    img_crop_type=3;
                    return true;
                elseif (img_size..'^' == value) then
                    img_crop_type=4;
                    return true;
                elseif (img_size..'>' == value) then
                    img_crop_type=5;
                    return true;
                elseif (img_size..'$' == value) then
                    img_crop_type=6;
                    img_size = img_width..'x';
                    return true;                    
                end
            end
        end
    end
    return false
end
 
-- 拼接gm命令
local function generate_gm_command(img_crop_type,img_original_path,img_size,img_thumbnail_path)
    local cmd
    cmd = c.gm_path .. ' convert ' .. img_original_path
    
    if (img_crop_type == 1) then
        cmd = cmd .. ' -thumbnail '  .. img_size .. ' -background ' .. c.img_background_color .. ' -gravity center -extent ' .. img_size
    elseif (img_crop_type == 2) then
        cmd = cmd .. ' -thumbnail '  .. img_size    
    elseif (img_crop_type == 3) then
        cmd = cmd .. ' -thumbnail "'  .. img_size .. '!" -extent ' .. img_size
    elseif (img_crop_type == 4) then
        cmd = cmd .. ' -thumbnail "'  .. img_size .. '^" -extent ' .. img_size
    elseif (img_crop_type == 5 or img_crop_type == 6) then
        cmd = cmd .. ' -resize "'  .. img_size .. '>"'
    else
        lua_log('img_crop_type error:'..img_crop_type,ngx.ERR);
        ngx.exit(404);
    end    
    cmd = cmd .. ' ' .. img_thumbnail_path
    return cmd
end
 
lua_log("ngx_thumbnail_root======="..ngx_thumbnail_root)
 
--[[
    1.判断原图是否存在,如原图不存在则进入下一步;如存在则跳至4
    2.判断是否显示默认图片,如不显示则404退出;如显示则进入下一步
    3.判断是否存在默认图片,如不存在则404退出;如存在则将默认图片代替原始图片,进入下一步;    
]]
local img_original_uri = string.gsub(uri, '_[0-9]+x[0-9]+','');
local img_exist=io.open(ngx_img_root .. img_original_uri);
if not img_exist then
    if not c.enabled_default_img then
        lua_log(img_original_uri..' is not exist!',ngx.ERR);
        ngx.exit(404);
    else
        img_exist=io.open(ngx_img_root ..  c.default_img_uri);
        if img_exist then
            lua_log(img_original_uri .. 'is not exist! crop image with default image');
            img_original_uri = c.default_img_uri;
        else
            lua_log(img_original_uri..' is not exist!',ngx.ERR);
            ngx.exit(404);
        end
    end;
end;
 
--[[
    4.判断缩略图链接与规则是否匹配,如不匹配,则404退出;如匹配跳至5
    5.拼接graphicsmagick,并执行
]]
if not table.contains(c.cfg, uri) then
    lua_log(uri..' is not match!',ngx.ERR);
    ngx.exit(404);
else
    local img_original_path  = ngx_img_root .. img_original_uri
    local img_thumbnail_path = ngx_thumbnail_root .. uri
    local gm_command         = generate_gm_command(img_crop_type,img_original_path,img_size,img_thumbnail_path)
    
    if (gm_command) then
        lua_log('gm_command======'..gm_command);
        _,_,img_thumbnail_dir,img__thumbnail_filename=string.find(img_thumbnail_path,'(.-)([^/]*)$')
        os.execute('mkdir -p '..img_thumbnail_dir);
        os.execute(gm_command);
    end
    ngx.req.set_uri('/thumbnail'..uri);
end

 

/usr/local/openresty/nginx/lua/config.lua

-- nginx thumbnail module 
-- last update : 2014/8/3
-- version     : 0.4
 
module(...,package.seeall)
 
enabled_log          = true
enabled_default_img  = true
default_img_uri      = '/default/notfound.jpg' 
gm_path                 = '/usr/local/graphicsmagick-1.3.18/bin/gm'
img_background_color = 'white'
 
--[[ 
    配置项,对目录、缩略图尺寸、裁剪类型进行配置,匹配后才进行缩略图处理
    1.sizes={'350x350'} 填充后保证等比缩图
    2.sizes={'300x300_'}等比缩图
    3.sizes={'250x250!'}非等比缩图,按给定的参数缩图(缺点:长宽比会变化)    
    4.sizes={'50x50^'}裁剪后保证等比缩图 (缺点:裁剪了图片的一部分)    
    5.sizes={'100x100>'}只缩小不放大        
    6.sizes={'140x140$'}限制宽度,只缩小不放大(比如网页版图片用于手机版时)    
]]
cfg = {
        {
            dir   = 'photos',
            sizes = {'50x50^','100x100>','140x140$','250x250!','300x300_','350x350'}
        },
        {    dir   = 'avatars',
            sizes = {'50x50^','80x80'}
        },
        {    dir   = 'default',
            sizes = {'50x50^','100x100>','140x140$','250x250!','300x300_','350x350','80x80'}
        }
}

  

 

六、监控脚本

 

我们的文件上传和删除由web程序来完成,当web程序删除原始文件时,需要同时删除缩略图,我们使用Linux的inotify来监控原始文件的变化,当有文件修改或删除时,删除相应的缩略图(注:inotify需要linux的内核版本大于等于2.6.13)。

 

脚本文件/home/shell/monitor_thumbnail.sh内容如下:

 

#!/bin/bash
basedir=/home/wwwroot/img.51ajax.com/
hostname=img.51ajax.com
thumbnaildir=thumbnail
excludedir=^${basedir}${thumbnaildir}
 
/usr/local/bin/inotifywait --exclude $excludedir -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f %e' --event delete,modify  ${basedir} | while read  date time file event
      do
                if [ "${file##*.}" = "jpg" -o "${file##*.}" = "jpeg"  -o "${file##*.}" = "gif" -o "${file##*.}" = "png" ];then
                        case $event in(DELETE|MODIFY)
                            tmpfile=${file/$hostname/$hostname\/$thumbnaildir};
                            filelist=${tmpfile%.*}_*.${tmpfile##*.};
                            for File in $filelist; do
                                    #echo "rm -rf "$File;
                                    rm -rf $File
                            done
                  ;;
                        esac
                  fi
      done

 

#加入启动

vi /etc/rc.d/rc.local

 

#增加下行

nohup /home/script/delete_thumbnail.sh &

关于inotify的更多资料,请参考:http://www.1987.name/637.html

 

七、参考文档

1、OpenResty官网

http://openresty.com/cn/index.html

2、HttpLuaModule模块介绍

http://wiki.nginx.org/HttpLuaModule

3、[老王]Nginx与Lua

http://huoding.com/2012/08/31/156

4、[老王]尝试使用GraphicsMagick的缩略图功能

http://hi.baidu.com/thinkinginlamp/item/753d86383545d10fcfb9fe14

5、GraphicsMagick安装及使用

http://www.cnblogs.com/javapro/archive/2013/04/28/3048393.html

6、Lua程序设计

http://book.luaer.cn/

7、灵活自定义缩略图片尺寸大小方案分享(nginx,lua_nginx,GraphicsMagick)

http://www.iteye.com/topic/1125126

8、揭?秘?淘?宝?2?8?6?亿?海?量?图?片?存?储?与?处?理?架?构

http://wenku.baidu.com/view/7dc77b2e7375a417866f8ff0.html

9、django-nginx-image

https://github.com/adw0rd/django-nginx-image

10、Lua中的正则表达式

http://blog.sina.com.cn/s/blog_512f462201016u3b.html

 

八、示例图片(图片来自老王博客)

 

原始图片(160×120)

 

1、填充后保证等比缩图(sizes={’350×350′} )

 

2、等比缩图(sizes={’300x300_’})

 

3、非等比缩图,按给定的参数缩图,长宽比会变化(sizes={’250×250!’})

 

4、裁剪后保证等比缩图,裁剪了图片的一部分(sizes={’50×50^’})

 

5、只缩小不放大(sizes={’100×100>’})

 

6、限制宽度,只缩小不放大(比如网页版图片用于手机版时)(sizes={’140×140$’})

 

原图不存在时

1、当配置显示默认图片,且路径及缩略图尺寸符合时,用默认图片填充

 

2、当配置不显示默认图片或路径及缩略图尺寸不符合时,返回404

 

九、写在最后

已在github创建项目:https://github.com/hopesoft/nginx-lua-image-module,有兴趣的同学可关注,后续如有时间会继续更新~

 

分享到:
评论

相关推荐

    缩略图OpenResty(Nginx)+Lua+GraphicsMagick

    OpenResty(Nginx+Lua)结合GraphicsMagick的解决方案,提供了一种强大的方法来实现这个目标。让我们深入探讨这个话题。 首先,OpenResty是一个基于Nginx Web服务器的扩展平台,它集成了LuaJIT,允许开发者用Lua...

    nginx+lua+redis实现token验证

    `lua`作为轻量级的脚本语言,可以增强`nginx`的功能,而`redis`则常用于高速缓存和分布式数据存储。本文将深入探讨如何利用`nginx+lua+redis`来实现`token`验证,以确保只有经过授权的用户才能访问受保护的资源。 ...

    nginx+lua+redis 集群 连接插件和脚本

    在构建高性能、高可用性的Web服务时,常常会利用到Nginx作为反向代理和负载均衡器,Lua作为扩展Nginx功能的脚本语言,而Redis则作为内存数据存储,提供快速的数据访问。本资源包“nginx+lua+redis集群 连接插件和...

    Nginx+upload+lua实现简单文件上传服务

    Nginx需要OpenResty(Nginx与lua的集成版)来执行lua脚本。安装OpenResty,并在Nginx配置中启用lua模块。 4. **编写lua脚本** 创建一个处理文件上传的lua脚本,例如`upload_handler.lua`,这个脚本会接收Nginx...

    Nginx+lua通过url传参的方式实现动态代理

    通过以上步骤,我们成功实现了基于Nginx+Lua的动态代理功能。这种方案不仅提高了系统的灵活性,还降低了维护成本。对于需要频繁调整后端服务地址的场景来说,这是一种非常实用且高效的解决方案。未来还可以进一步...

    第一章 安装OpenResty(Nginx+Lua)开发环境

    OpenResty是一个开源项目,它集成了Nginx服务器和LuaJIT,允许开发者在Nginx上编写 Lua 脚本,从而实现复杂的功能,如流量控制、缓存处理、API网关等。利用Lua的轻量级特性,OpenResty可以提高Web应用的响应速度,...

    idea openrestry+nginx+lua搭建企业级开发环境

    在 OpenResty 中,Lua 能够与 Nginx 的 C 代码紧密交互,实现高性能的网络编程。通过 Lua,开发者可以快速实现复杂的功能,比如 URL 解析、会话管理、数据缓存等。同时,Lua 的模块系统也使得代码组织和重用变得简单...

    openresty + lua-resty-weedfs + graphicsmagick小文件部署方案

    将图片的上传,分布式管理 交由seaweedfs管理,可提供更快的响应速度,更方便,无痛的分布式扩展节点,billion 级别的。后面使用openresty + lua-resty-weedfs + graphicsmagick 生成缩略图功能独立处理。

    2 OpenResty+Lua+Redis 高性能后端接口.docx

    OpenResty+Lua+Redis 高性能后端接口 OpenResty 是基于 Nginx 的高性能 web 服务器,它使用 Lua 语言作为脚本语言来实现动态内容生成和处理。 Lua 是一种轻量级的脚本语言,广泛应用于游戏、嵌入式系统和 web 开发...

    idea+openresty+lua运行nginx服务器.zip

    idea+openresty+lua运行nginx服务器, 代码和软件都有, 参考资料: https://blog.csdn.net/dongyuxu342719/article/details/90413904

    基于nginx+lua+dyups实现服务自定义调度资源整理

    本文将详细讲解如何利用`nginx`、`lua`和`dyups`实现服务自定义调度,并探讨相关知识点。 **一、自定义服务调度** 自定义服务调度允许根据不同的客户端请求条件,如IP地址、用户标识、请求头等,将请求智能地转发...

    跟我学Nginx+Lua开发

    因为是懒人直接采用了整个安装openresty的策略,当然你也可以单独安装nginx,再安装lua,然后nginx_lua_module。安装了openresty之后,开始写简单的测试,其实在openresty的github上也有相关的例子,可以对着例子...

    Nginx+Lua阿⾥实战经验谈.pdf

    《Nginx+Lua阿里巴巴实战经验谈》 Nginx+Lua在阿里巴巴的实践中扮演了重要角色,尤其在阿里巴巴云CDN事业部的应用中,这一组合展现出了强大的效能和灵活性。Nginx+Lua的起源可以追溯到淘宝时期,由创始人王晓哲和章...

    京东李开涛 跟我学Nginx+Lua 开发

    它不仅包含了标准Nginx的核心功能,还集成了LuaJIT运行时环境,允许开发者直接在Nginx内部使用Lua脚本编写高性能的应用程序逻辑。 - **核心优势**: - **高性能**:OpenResty利用Nginx的事件驱动模型和非阻塞I/O...

    跟我学Nginx + Lua开发

    将Nginx与Lua结合,可以使Nginx不仅仅作为一个静态内容服务器,还可以执行动态内容的生成,大大扩展了Nginx的功能。 OpenResty是基于Nginx与LuaJIT的一个高性能Web平台,它以标准Nginx核心,集成了大量的精心设计的...

    跟我学Nginx+Lua开发.pdf

    OpenResty就是这一结合的最佳体现,它将Nginx的核心功能与Lua的灵活性完美融合,为开发者提供了一个理想的平台来创建高性能的Web应用和服务。 #### 二、OpenResty安装与配置 **1. 环境准备** - **创建目录**: ...

    nginx+lua简要说明

    lua模块,并且将Nginx核心、LuaJIT、ngx_lua模块、许多有用的Lua库和常用的第三方Nginx模块组合在一起成为OpenResty,这样开发人员就可以安装OpenResty,使用Lua编写脚本,然后部署到Nginx Web容器中运行。...

Global site tag (gtag.js) - Google Analytics