nginx - openresty無法使用require
PHPz
PHPz 2017-05-16 17:07:47
0
1
717

不讓·access_check.lua的時候,程式運作正常,使用就會出現錯誤。
環境使用了dockeropenresty/openresty官方映像。

nginx.conf配置如下:

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}

http {
    lua_package_path "lua/?.lua;app/?.lua";
    lua_code_cache off;

    server {
        listen 6699;
        charset utf-8;
        #lua_need_request_body on;

        location / {
            default_type text/html;

            content_by_lua_block {
                ngx.say("hello fatrbaby")
            }
        }

        location ~ ^/api/([-_a-zA-Z0-9/]+) {
            access_by_lua_file  lua/access_check.lua;
            content_by_lua_file lua/.lua;
        }
    }
}

access_check.lua程式碼如下:

local validator = require("lib.validator")

local args = ngx.req.get_uri_args()

if not validator.is_number(args.a, args.b) then
    ngx.exit(ngx.HTTP_BAD_REQUEST)
    return
end
ngx.print(package.path)

錯誤日誌如下:

2017/04/26 09:11:34 [error] 216#216: *1 lua entry thread aborted: runtime error: /usr/local/var/learn/lua/access_check.lua:1: module 'lib.validator' not found:
    no field package.preload['lib.validator']
    no file 'lua/lib/validator.lua'
    no file 'app/lib/validator.lua'
    no file '/usr/local/openresty/site/lualib/lib/validator.so'
    no file '/usr/local/openresty/lualib/lib/validator.so'
    no file './lib/validator.so'
    no file '/usr/local/lib/lua/5.1/lib/validator.so'
    no file '/usr/local/openresty/luajit/lib/lua/5.1/lib/validator.so'
    no file '/usr/local/lib/lua/5.1/loadall.so'
    no file '/usr/local/openresty/site/lualib/lib.so'
    no file '/usr/local/openresty/lualib/lib.so'
    no file './lib.so'
    no file '/usr/local/lib/lua/5.1/lib.so'
    no file '/usr/local/openresty/luajit/lib/lua/5.1/lib.so'
    no file '/usr/local/lib/lua/5.1/loadall.so'
stack traceback:
coroutine 0:
    [C]: in function 'require'
    /usr/local/var/learn/lua/access_check.lua:1: in function </usr/local/var/learn/lua/access_check.lua:1>, client: 172.17.0.1, server: , request: "GET /api/add?a=1&b=6 HTTP/1.1", host: "localhost:6699"

專案目錄結構如下:

#
PHPz
PHPz

学习是最好的投资!

全部回覆(1)
左手右手慢动作

已經解決了這個問題

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板