nginx是一个高性能的反向代理服务器,lua是一个小巧的脚本语言,利用lua-nginx-module模块可以使用lua处理nginx请求,下面将一步步介绍如何编译带lua-nginx-module的nginx。
1.下载源码
编译带lua-nginx-module模块的nginx,需要用到下面6个源码包。
- luajit2-2.1-20201027.tar.gz
- lua-nginx-module-0.10.19.tar.gz
- lua-resty-core-0.1.21.tar.gz [非必须]
- lua-resty-lrucache-0.10.tar.gz [非必须]
- nginx-1.19.5.tar.gz
- ngx_devel_kit-0.3.1.tar.gz
2. 编译LuaJIT
lua-nginx-module 依赖LuaJIT 2.x,ngx_devel_kit,所以编译带lua-nignx-module模块的nginx之前必须先编译LuaJIT,具体的要求可以看下面官网的说明原文。
1. LuaJIT can be downloaded from the latest release of OpenResty's LuaJIT fork. The official LuaJIT 2.x releases are also supported, although performance will be significantly lower for reasons elaborated above
2. Download the latest version of the ngx_devel_kit (NDK) module HERE
3. Download the latest version of ngx_lua HERE
4. Download the latest supported version of Nginx HERE (See Nginx Compatibility)
解压、编译并安装LuaJIT
sudo tar zxvf luajit2-2.1-20201027.tar.gz
sudo make install PREFIX=/usr/local/LuaJIT
这里指定安装的路径为/usr/local/LuaJIT
,如果成功编译将可以看到如下结果:
3. 编译nginx
首先安装nginx必要的依赖pcre pcre-devel zlib zlib-devel openssl-devel:
sudo apt-get install libpcre3 libpcre3-dev
sudo apt-get install zlib1g-dev
sudo apt-get install openssl libssl-dev
# 如果是Centos系统,则使用下面的命令
# yum install pcre pcre-devel
# yum install zlib zlib-devel
# yum install openssl-devel
然后解压需要的源码包:
sudo tar zxvf nginx-1.19.5.tar.gz
sudo tar zxvf ngx_devel_kit-0.3.1.tar.gz
sudo tar zxvf lua-nginx-module-0.10.19.tar.gz
编译nginx这里有个坑,官网的说明文档是设置LUAJIT_LIB
和LUAJIT_INC
这两个变量即可,即下面的命令:
export LUAJIT_LIB=/path/to/luajit/lib
export LUAJIT_INC=/path/to/luajit/include/luajit-2.1
但是实测发现,这个方案并不行,lua-nginx-module的config还是走了auto-discovery
的流程,由于上面自己指定了LuaJIT的安装路径,auto-discovery
并不能发现LuaJIT,在nginx configure的时候,就会报下面这个错误:
checking for LuaJIT 2.x ... not found
./configure: error: unsupported LuaJIT version; ngx_http_lua_module requires LuaJIT 2.x.
最后无奈,我将这两个变量直接写死在lua-nginx-module的config中,即:
# 直接声明这两个变量
LUAJIT_INC=/usr/local/LuaJIT/include/luajit-2.1
LUAJIT_LIB=/usr/local/LuaJIT/lib
ngx_lua_opt_I=
ngx_lua_opt_L=
luajit_ld_opt=
ngx_feature_name=
ngx_feature_run=no
ngx_feature_incs=
ngx_feature_test=
# 使得config走if流程
if [ -n "$LUAJIT_INC" -o -n "$LUAJIT_LIB" ]; then
....
配置nginx编译选项:
sudo ./configure \
--prefix=/usr/local/nginx \
--sbin-path=/usr/local/nginx/nginx \
--conf-path=/usr/local/nginx/nginx.conf \
--pid-path=/usr/local/nginx/nginx.pid \
--error-log-path=/usr/local/nginx/logs/error.log \
--with-http_ssl_module \
--with-ld-opt="-Wl,-rpath,/usr/local/LuaJIT/lib" \
--add-module=/usr/local/src/ngx_devel_kit-0.3.1 \
--add-module=/usr/local/src/lua-nginx-module-0.10.19
如果配置成功,将可以看到如下信息:
执行编译:
sudo make
编译成功的话,可以看到如下信息:
安装nginx,配置指定的nginx安装路径为:/usr/local/nginx。
4. 编译lua-resty-core
lua-resty-core 提供了很多api,在使用nginx + lua 开发时用的最多,所以将以这个为例编译nginx lua依赖库,lua-resty-core依赖lua-resty-lrucache模块,所以这两个模块要一起安装:
sudo tar zxvf lua-resty-core-0.1.21.tar.gz
sudo tar zxvf lua-resty-lrucache-0.10.tar.gz
cd lua-resty-core-0.1.21
sudo make install PREFIX=/usr/local/LuaLIB
cd ../lua-resty-lrucache-0.10
sudo make install PREFIX=/usr/local/LuaLIB
这里将这两个模块都安装在/usr/local/LuaLIB。
5. 编写lua指令处理nginx请求
nginx编译完成之后就可以使用lua脚本来处理nginx请求了,先上一个Hello World示例,调整nginx.conf:
http {
# 指定lua模块路径,多个之间";"分隔,其中";;"表示默认搜索路径,默认到nginx的根目录下找
lua_package_path "/usr/local/LuaLIB/lib/lua/?.lua;;";
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
# 使用lua-resty-core输出一个字符串
location /lua {
default_type 'text/html';
content_by_lua 'ngx.say("Hi Lua")';
}
location / {
root html;
index index.html index.htm;
}
}
}
请求/lua可以看到如下效果,就说明nginx + lua-nginx-module编译成功了。
关于更多的 lua-resty-core api可以查看下面官网的文档:
https://github.com/openresty/lua-resty-core
=========================================================
文中用到的源码包可关注公众号 “HiIT青年” 发送 “nginx-lua” 获取。
关注公众号,阅读更多文章。