Lua 无法导入模块并提示文件不存在,但文件确实存在

我正在尝试在 haproxy 内部运行 lua 脚本,导入“pgmoon”库。我可以导入 pgmoon 并打开套接字,但随后遇到以下问题:

[ALERT] 082/234313 (8) : Lua function 'queue-request': runtime error: /usr/local/share/lua/5.3/pgmoon/init.lua:269: module 'pgmoon.crypto' not found:
no field package.preload['pgmoon.crypto']
no file '/usr/local/share/lua/5.3/pgmoon/crypto.lua'
no file '/usr/local/share/lua/5.3/pgmoon/crypto/init.lua'
no file '/usr/local/lib/lua/5.3/pgmoon/crypto.lua'
no file '/usr/local/lib/lua/5.3/pgmoon/crypto/init.lua'
no file '/usr/share/lua/5.3/pgmoon/crypto.lua'
no file '/usr/share/lua/5.3/pgmoon/crypto/init.lua'
no file './pgmoon/crypto.lua'
no file './pgmoon/crypto/init.lua'
no file '/usr/local/lib/lua/5.3/pgmoon/crypto.so'
no file '/usr/lib/x86_64-linux-gnu/lua/5.3/pgmoon/crypto.so'
no file '/usr/lib/lua/5.3/pgmoon/crypto.so'
no file '/usr/local/lib/lua/5.3/loadall.so'
no file './pgmoon/crypto.so'
no file '/usr/local/lib/lua/5.3/pgmoon.so'
no file '/usr/lib/x86_64-linux-gnu/lua/5.3/pgmoon.so'
no file '/usr/lib/lua/5.3/pgmoon.so'
no file '/usr/local/lib/lua/5.3/loadall.so'
no file './pgmoon.so' from [C] global 'require', /usr/local/share/lua/5.3/pgmoon/init.lua:269 C function line 267 ..., /usr/local/share/lua/5.3/pgmoon/init.lua:211 method 'connect', /usr/local/haproxy/queue-request.lua:38 C function line 25.

但是,确实存在 /usr/local/share/lua/5.3/pgmoon/crypto.lua 这个文件,ls 显示如下:

# ls -la /usr/local/share/lua/5.3/pgmoon/
total 60
drwxr-xr-x 1 root root  4096 Mar 24 23:42 .
drwxr-xr-x 1 root root  4096 Mar 24 23:00 ..
-rw-r--r-- 1 root root  2880 Mar 24 23:00 arrays.lua
-rw-r--r-- 1 root root  1130 Mar 24 23:00 bit.lua
-rw-r--r-- 1 root root  1587 Mar 24 23:00 cqueues.lua
-rw-r--r-- 1 root root   654 Mar 24 23:00 crypto.lua
-rw-r--r-- 1 root root  2084 Mar 24 23:00 hstore.lua
-rw-r--r-- 1 root root 20127 Mar 24 23:00 init.lua
-rw-r--r-- 1 root root   665 Mar 24 23:00 json.lua
-rw-r--r-- 1 root root  2728 Mar 24 23:42 socket.lua
-rw-r--r-- 1 root root   457 Mar 24 23:00 util.lua

如果 haproxy 用户无法访问 root 拥有的文件,则我可以将其视为与权限相关,但是当它到达此处时,已经执行了导入了 socket.lua 的 init.lua,它们都具有相同的权限... 有人知道 lua 为什么认为在 crypto.lua 中不存在文件吗?

点赞
用户1236045
用户1236045

我猜测您已经使用chroot配置了haproxy,在haproxy所在的chroot中实际上没有/usr/local/share/lua/5.3/pgmoon/crypto.lua这个文件。

init.lua中的require('pgmoon.crypto')位于一个函数中,并且可能会在Haproxy和lua初始化以及根目录更改后很久才尝试运行。

而且,与此(不)关联的是——您可能会因为pgmoon不知道haproxy而遇到其他问题,例如它使用luasocket而不是haproxy提供的替代品:https://www.haproxy.com/blog/5-ways-to-extend-haproxy-with-lua/

Socket类是标准Lua Socket类的替代品,并且与HAProxy的非阻塞性质兼容。当您想在操作中使用socket函数时,必须使用此类。

2021-03-25 14:38:01