Nginx安装lua支持

Nginx安装lua支持

需要LuaJIT-2.0.4.tar.gz,ngx_devel_kit,lua-nginx-module

1.下载安装LuaJIT-2.0.4.tar.gz

wget -c http://luajit.org/download/LuaJIT-2.0.4.tar.gz

tar xzvf LuaJIT-2.0.4.tar.gz

cd LuaJIT-2.0.4

make install PREFIX=/usr/local/luajit

#注意环境变量!

export LUAJIT_LIB=/usr/local/luajit/lib

export LUAJIT_INC=/usr/local/luajit/include/luajit-2.0

2.下载解压ngx_devel_kit

wget https://github.com/simpl/ngx_devel_kit/archive/v0.3.0.tar.gz

tar -xzvf v0.3.0.tar.gz

3.下载解压lua-nginx-module

wget https://github.com/openresty/lua-nginx-module/archive/v0.10.8.tar.gz

tar -xzvf v0.10.8.tar.gz

4.下载安装nginx-1.10.3.tar.gz

wget http://nginx.org/download/nginx-1.10.3.tar.gz

tar -xzvf nginx-1.10.3.tar.gz

cd nginx-1.10.3

./configure --add-module=/opt/soft/ngx_devel_kit-0.3.0 --add-module=/opt/soft/lua-nginx-module-0.10.8

#注意ngx_devel_kit和lua-nginx-module以实际解压路径为准

make -j2

make install

注:报错gcc需要安装,可以执行

yum install -y gcc g++ gcc-c++

依赖报错,可以执行

yum -y install zlib zlib-devel openssl openssl--devel pcre pcre-devel

这样会导致编好的nginx在启动的时候会无法找到位于luajit内的类库,类似于

/opt/nginx/sbin/nginx -c /opt/nginx/conf/nginx.conf/opt/nginx/sbin/nginx: error while loading shared libraries: libluajit-5.1.so.2: cannot open shared object file: No such file or directory

这个问题很多人发现后采用了将libluajit-5.1.so.2链接到系统库的做法,比如http://cywhoyi.iteye.com/blog/2118913,以及https://www.ttlsa.com/nginx/nginx-modules-ngx_lua,采用的

ln -s /usr/local/lib/libluajit-5.1.so.2 /lib64/

这样可以解决问题,但是相当于一个补救方法。

利用nginx+lua实现通用的请求输入输出日志打印

nginx+lua在web开发中现在越来越多用于实现一些公共策略逻辑,比如防攻击等,nginx有着高性能高并发的处理框架,lua语言开发也简单,这次我们尝试在nginx层用lua实现我们请求日志的打印。

在开发调试、问题排查中,日志信息很重要,尤其是一个请求的输入及输出信息,但nginx本身的日志定义不能打印输出信息及POST参数,我们往往会在后端业务代码中(如用PHP)打印一个这样的notice日志,不过也可以在nginx中用lua中实现,所有经过这个nginx的请求日志都会按你想要的格式打印出来,这样实现简单而且统一。下面介绍下我在nginx中用lua实现的一个日志打印脚本。

nginx+lua的具体开发教程见这里 https://github.com/openresty/lua-nginx-module,我就不介绍了,下面主要是介绍一下实现代码:

我们要建立nginx各个处理阶段的代码文件,首先创建一个access.lua文件,代码如下:

if ngx.var.log_val ~= nil then
    local request = "["..ngx.var.time_local.."] ".."\""..ngx.var.request_method.." "..ngx.var.scheme.."://"..
                     ngx.var.host..ngx.var.request_uri.."\""
    local post = ""
    local delimiter = ""
    local item = ""
    ngx.req.read_body()    local args, err = ngx.req.get_post_args()    if args then
        for key, val in pairs(args) do
           item = ""
           if type(val) == "string" then
               key =  string.gsub(key,"%c"," ")
               val = string.gsub(val,"%c"," ")
               item = key.."="..val           elseif type(val) == "table" then
               item = key.."="
               local tstr = "";               local tdelimiter = ""
               for k, v in pairs(val) do
                   if type(v) == "string" then
                      tstr = tstr..tdelimiter..v
                      tdelimiter = ‘,‘
                   end
               end
               item = item..tstr           end
           post = post..delimiter..item
           delimiter = "&"
        end
    end

    ngx.var.log_val = request.."      ".."  postdata=["..post.."]   output=["end1234567891011121314151617181920212223242526272829303132333412345678910111213141516171819202122232425262728293031323334

这个文件主要是记录请求的时间、url及输入参数等信息,包括post数据

接着创建一个body_filter.lua文件,内容如下:

if ngx.var.log_val ~= nil then
    local newcontent = string.gsub(ngx.arg[1],"%c"," ")
    ngx.var.log_val = ngx.var.log_val..newcontentend12341234

这里记录输出信息,开发中发现ngx.arg[1]与任何字符串进行连接的话,日志打印都会打印两次,除了与内置log_val变量连接,原因可能跟内部跳转有关,所以这里就两行代码,不会有更多其它操作。

再创建一个log.lua文件,内容如下:

if ngx.var.log_val ~= nil then
    function mylog(msg)
        file = io.open ("/home/rong/nginx/logs/monitor.log","a+")
        file:write (msg)
        file:flush();
        file:close();
    end

    ngx.var.log_val = ngx.var.log_val.."]      httpstatus="..
                      ngx.var.status.." request_time="..ngx.var.request_time.."\n"
    mylog(ngx.var.log_val)
end123456789101112123456789101112

这里将拼接起来的各个日志信息写入文件。

创建了各个阶段的处理文件,将其加入nginx配置文件中,如下:

 ......
 access_by_lua_file /home/rong/nginx/conf/access.lua;
 body_filter_by_lua_file /home/rong/nginx/conf/body_filter.lua;
 log_by_lua_file /home/rong/nginx/conf/log.lua; .....1234512345

注意nginx配置中 client_body_buffer_size 与 client_max_body_size的值要设得一样大,且不能过小。

最后还要在server段定义一个变量,作为存储每条日志信息用

server{     ......
     set $log_val ‘‘;     ......}123456123456

这样,有请求过来时,在 /home/rong/nginx/logs/monitor.log文件 中就可以很清楚地看到输入输出信息了。

时间: 2024-10-23 06:34:39

Nginx安装lua支持的相关文章

nginx 安装并支持upstream监控

nginx安装并支持upstream和tcp代理模块 yum groupinstall "Development tools" yum -y install pcre-devel openssl openssl-devel git wget http://nginx.org/download/nginx-1.4.5.tar.gz tar zxvf nginx-1.4.5.tar.gz cd nginx-1.4.5 git clone https://github.com/yaoweib

Let's Encrypt: 为CentOS/RHEL 7下的nginx安装https支持-具体案例

环境说明: centos 7 nginx 1.10.2 前期准备 软件安装 yum install -y epel-release yum install -y certbot 创建目录及链接 方法1:在网站根目录下创建一个.well-known的目录 方法2: mkdir -p /usr/local/nginx/cert/.well-known ln -s /usr/local/nginx/cert/.well-known /data/www/example.com/.well-known l

nginx安装lua模块实现高并发

nginx安装lua扩展模块 1.下载安装LuaJIT-2.0.4.tar.gz wget -c http://luajit.org/download/LuaJIT-2.0.4.tar.gz tar xzvf LuaJIT-2.0.4.tar.gz cd LuaJIT-2.0.4 make install PREFIX=/usr/local/luajit #注意环境变量! export LUAJIT_LIB=/usr/local/luajit/lib export LUAJIT_INC=/usr

nginx安装lua/replace-filter-nginx-module

nginx加载lua和replace-filter-nginx-module模块一.lua部分首先下载和安装部分模块1.下载安装LuaJIT官网:http://luajit.org/下载链接:http://luajit.org/download/LuaJIT-2.1.0-beta3.tar.gz wget http://luajit.org/download/LuaJIT-2.1.0-beta3.tar.gz tar zxvf LuaJIT-2.1.0-beta3.tar.gz cd LuaJI

nginx安装https支持

安装软件yum install openssll nginx 在特定目录下生成证书mkdir /usr/share/nginx/confcd /usr/share/nginx/confopenssl genrsa -des3 -out server.key 1024生成服务器端的私钥server.keyopenssl req -new -key server.key -out server.csr生成的csr文件交给CA签名后形成服务端自己的证书,输入证书信息,国家.地区.公司.邮箱等opens

nginx安装并支持upstream和tcp代理模块

wget http://nginx.org/download/nginx-1.4.5.tar.gz tar zxvf nginx-1.4.5.tar.gz cd nginx-1.4.5 Git clone https://github.com/yaoweibin/nginx_upstream_check_module.git //upstream模块 git clone https://github.com/yaoweibin/nginx_tcp_proxy_module.git //tcp代理

nginx 安装第三方模块(lua)并热升级

需求: nginx上将特定请求拒绝,并返回特定值. 解决办法: 使用lua脚本,实现效果. 操作步骤: 安装Luajit环境 重新编译nginx(原先nginx -V 配置一致,并新增两个模块ngx_devel_kit,lua-nginx-module) 热升级(不中断服务) 配置文件添加lua脚本: #匹配请求体里的 hello=world时返回此变量和值 location /hello { rewrite_by_lua_block { ngx.req.read_body() local ow

17. Nginx与Lua开发

安装 Lua 和 Lua for nginx #安装lua yum install -y lua lua -v 安装更高效的 Lua 语言解释器 LuaJIT wget http://luajit.org/download/LuaJIT-2.0.2.tar.gz tar -zxvf LuaJIT-2.0.2.tar.gz cd LuaJIT-2.0.2 make install PREFIX=/usr/local/LuaJIT/2.0.2 export LUAJIT_LIB=/usr/local

【linux】之Nginx安装使用和配置SSL支持

本文采用的是nginx源码安装 1.下载nginx源码包 wget http://nginx.org/download/nginx-1.8.0.tar 或者登录nginx官网下载更高版本 2.nginx安装需要其他环境的支持 环境是否安装了gcc rpm -qa|grep gcc 如果没有则需要yum install gcc-c++ 环境是否安装了pcre 该文件为正则表达式库.让nginx支持rewrite需要安装这个库 如果没有安装可以采用yum安装  yum -y install pcre