Lua reescrita de Nginx com sabor ou ciclo de redirecionamento interno

1

Sou novo em nginx e lua . Estou tentando seguir este tutorial link mas, para o resto de mim, não consigo obter o nginx.conf direito.

Eu verifiquei outras perguntas semelhantes a esta onde o problema está location , mas não consigo ver o que há de errado com o meu código.

Aqui está o nginx.conf :

error_log stderr notice;
daemon off;

events { }

http {
  include /usr/local/openresty/nginx/conf/mime.types;

  server {
    listen 6789;
    lua_code_cache on;

    location @image_server {
      content_by_lua_file "serve_image.lua";
    }

    location ~ ^/images/(?<size>[^/]+)/(?<path>.*\.(?<ext>[a-z_]*))$ {
      root cache;
      try_files /$path @image_server;
    }

  }
}

E este é o código serve_image.lua

local sig, size, path, ext =

ngx.var.sig, ngx.var.size, ngx.var.path, ngx.var.ext     local images_dir="images /" - de onde as imagens vêm     cache_dir="cache /" local - onde as imagens são armazenadas em cache

local function return_not_found(msg)
  ngx.status = ngx.HTTP_NOT_FOUND
  ngx.header["Content-type"] = "text/html"
  ngx.say(msg or "not found")
  ngx.exit(0)
end

local source_fname = images_dir .. path
ngx.log(ngx.STDERR, "->>>>  " .. source_fname)

-- make sure the file exists
local file = io.open(source_fname)

if not file then
  ngx.log(ngx.STDERR, "Couldn't find the input file" .. source_fname)
  return_not_found()
end

file:close()

local dest_fname = cache_dir .. "/" .. size .. "/" .. path

-- resize the image
local magick = require("magick")
magick.thumb(source_fname, size, dest_fname)

ngx.exec(ngx.var.request_uri)

Quando eu executo o servidor, recebo um código 500.

Este é o erro no terminal

rewrite or internal redirection cycle while redirect to named location "@image_server", client: 127.0.0.1, server: , request: "GET /images/80x80/wow.png HTTP/1.1", host: "localhost:6789"

Espero que um par de olhos mais experiente e novo possa apontar o que estou fazendo de errado. Obrigado.

    
por U r s u s 13.10.2015 / 12:35

0 respostas

Tags