前言:由于项目中nginx日志中配置了 response_body ,之前使用一直正常结果,最近项目需求上传视频,这下问题来了,一下子服务器内存就被nginx日志占满了。为了保证日常post接口遇到问题能定位,又不能打印太长的nginx 日志 决定使用lua模块来截取response_body。
第一步需要安装LuaJIT
cd /usr/local/src
wget https://github.com/openresty/luajit2/archive/refs/tags/v2.1-20201229.tar.gz# 解压缩文件夹
tar -zxvf v2.1-20201229.tar.gz
# 编译和安装
make PREFIX=/usr/local/luajit
make install PREFIX=/usr/local/luajit
成功之后会有一个 Successfully
配置LuaJIT环境变量
# ======临时生效的可以执行如下脚本======
export LUAJIT_LIB=/usr/local/luajit/lib
export LUAJIT_INC=/usr/local/luajit/include/luajit-2.1
# ======永久生效的可以执行如下脚本======
cat >> /etc/profile <<END
export LUAJIT_LIB=/usr/local/luajit/lib
export LUAJIT_INC=/usr/local/luajit/include/luajit-2.1 END
# 使/etc/profile立刻生效
source /etc/profile
第二部Nginx Module下载
1.ngx_devel_kit
NDK(nginx development kit)模块是一个拓展nginx服务器核心功能的模块,第三方模块开发可以基于它来快速实现。NDK提供函数和宏处理一些基本任务,减轻第三方模块开发的代码量。
$ mkdir -p /usr/local/src/nginx-modules
$ cd /usr/local/src/nginx-modules
$ wget https://github.com/vision5/ngx_devel_kit/archive/v0.3.1.tar.gz
# 上面的地址如果下载不了,可以使用以下加速地址
$ wget https://github.91chifun.workers.dev/https://github.com//vision5/ngx_devel_kit/archive/refs/tags/v0.3.1.tar.gz
$ tar -xvf v0.3.1.tar.gz
2.lua-nginx-module
将Lua的功能嵌入到Nginx HTTP服务器中。
$ cd /usr/local/src/nginx-modules
$ wget https://github.com/openresty/lua-nginx-module/archive/v0.10.14.tar.gz
# 上面的地址如果下载不了,可以使用以下加速地址
$ wget https://github.91chifun.workers.dev/https://github.com//openresty/lua-nginx-module/archive/refs/tags/v0.10.14.tar.gz
$ tar -xvf v0.10.14.tar.gz
注 如果以上都无法下载可以用复制链接到浏览器上下载,然后上传服务器
由于我的项目是已经有nginx了 所以我这边会麻烦一点 流程分为几步
1.查看当前 nginx配置情况
nginx -V
这是我们项目的配置会复杂一点有很多插件
2.找到nginx的安装包一般是在 /usr/local/src里面
cd /usr/local/src/nginx-1.18.0
./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --with-http_ssl_module --with-http_stub_status_module --add-module=/usr/local/src/nginx-modules/ngx_devel_kit-0.3.1 --add-module=/usr/local/src/nginx-modules/lua-nginx-module-0.10.14/
注: 别直接运行 查看一下你自己项目的nginx配置地址 以及两个modules的位置 如果像我有其他的配置记得要加上
成功之后
make
注:别make install 会覆盖
然后就是
cp /usr/sbin/nginx /usr/sbin/nginx.bak
#记得要关闭nginx
cp ./objs/nginx /usr/sbin/
nginx -V
如下就OK
这个地方会有一些报错
安装nginx环境(含lua)时遇到报错ngx_http_lua_common.h:20:20: error: luajit.h: No such file or directory的解决
解决方法:把lib的路径写入/etc/profile中
# vim /etc/profile
export LUAJIT_LIB=/usr/local/lib
export LUAJIT_INC=/user/local/include/luajit-2.1
# source /etc/profile
重新编译即可成功!