Nginx安装Lua

Nginx安装Lua

1.安装Lua(两个二选一)

yum install readline-devel (CentOS)
sudo apt-get install libreadline-dev (Ubuntu)

sudo apt-get install libncurses5-dev (Ubuntu)
wget -O LuaJIT-2.0.4.tar.gz http://luajit.org/download/LuaJIT-2.0.4.tar.gz

tar -zxvf LuaJIT-2.0.4.tar.gz

make && make install
wget -O lua-5.1.5.tar.gz http://www.lua.org/ftp/lua-5.1.5.tar.gz

tar -zxvf lua-5.1.5.tar.gz

make linux test

检查libluajit-5.1.so.2.0.4库是否存在

ls /usr/local/lib

2.准备nginx插件
shell 复制代码
wget -O ngx_devel_kit_v0.3.0.tar.gz https://github.com/simpl/ngx_devel_kit/archive/v0.3.0.tar.gz 
tar -zxvf ngx_devel_kit_v0.3.0.tar.gz

wget -O lua-nginx-module.zip https://github.com/openresty/lua-nginx-module/archive/master.zip
unzip lua-nginx-module.zip

git clone https://github.com/zebrafishlabs/nginx-statsd.git
3.安装nginx
shell 复制代码
wget http://nginx.org/download/nginx-1.10.2.tar.gz
tar -zxvf nginx-1.10.2.tar.gz
cd nginx-1.10.2

./configure --prefix=/data/beyond/nginx \
    --pid-path=/data/logs/nginx/nginx.pid \
    --lock-path=/data/beyond/nginx/nginx.lock \
    --error-log-path=/data/logs/nginx/error.log \
    --http-log-path=/data/logs/nginx/access.log \
    --http-client-body-temp-path=/data/temps/nginx/client_body_temp \
    --http-proxy-temp-path=/data/temps/nginx/proxy_temp \
    --http-fastcgi-temp-path=/data/temps/nginx/fastcgi_temp \
    --http-uwsgi-temp-path=/data/temps/nginx/uwsgi_temp \
    --http-scgi-temp-path=/data/temps/nginx/scgi_temp \
    --with-http_stub_status_module \
    --with-http_ssl_module \
    --with-http_stub_status_module \
    --with-http_ssl_module \
    --with-ld-opt="-Wl,-rpath,/usr/local/lib" \
    --add-module=/data/software/ngx_devel_kit-0.3.0 \
    --add-module=/data/software/lua-nginx-module-master \
    --add-module=/data/software/nginx-statsd \
    --with-pcre=/data/software/pcre-8.35


make -j2
make install

注意: 安装的 openssl 版本若是 1.0.1---1.0.1f / 1.0.2 Beta1(可通过 openssl version 查看),则需重新手动安装,否则会有心血漏洞的隐患。可参照本文下方的操作步骤编译安装。

注:

  • 若 openssl 的版本 >= 1.1.0,nginx lua module 编译时会报错,需要重新安装 openssl,安装过程如下:
1.安装 openssl

wget https://www.openssl.org/source/openssl-1.0.2k.tar.gz
tar -zxvf openssl-1.0.2k.tar.gz
cd openssl-1.0.2k
./config --prefix=/usr/local/openssl-1.0.2k -fPIC shared
make && make install

2.若已经安装了自带的 openssl,可通过 ldd (which nginx) (这里的 (which nginx) 是指 nginx 可执行文件的位置)查看 nginx 所依赖的 ssl 的库文件位置(一般是在 /lib64/ 目录下的软连接),备份好软连接,然后将其指向新安装的位置

ldd $(which nginx)

libssl.so.1.0.0 => /lib64/libssl.so.10

libcrypto.so.1.0.0 => /lib64/libcrypto.so.10

mv /lib64/libssl.so.10 /lib64/libssl.so.10_old
mv /lib64/libcrypto.so.10 /lib64/libcrypto.so.10_old
ln -sv /usr/local/openssl-1.0.2k/lib/libssl.so.1.0.0 /lib64/libssl.so.10
ln -sv /usr/local/openssl-1.0.2k/lib/libcrypto.so /lib64/libcrypto.so.10

3.进入 nginx 源码目录,修改 auto/lib/openssl/conf 文件
复制代码
把

            CORE_INCS="$CORE_INCS $OPENSSL/.openssl/include"
            CORE_DEPS="$CORE_DEPS $OPENSSL/.openssl/include/openssl/ssl.h"
            CORE_LIBS="$CORE_LIBS $OPENSSL/.openssl/lib/libssl.a"
            CORE_LIBS="$CORE_LIBS $OPENSSL/.openssl/lib/libcrypto.a"
            
修改成

            CORE_INCS="$CORE_INCS $OPENSSL/include"
            CORE_DEPS="$CORE_DEPS $OPENSSL/include/openssl/ssl.h"
            CORE_LIBS="$CORE_LIBS $OPENSSL/lib/libssl.a"
            CORE_LIBS="$CORE_LIBS $OPENSSL/lib/libcrypto.a"
4.make clean 之后,重新 configure,但选项中添加一项 --with-openssl=/usr/local/openssl-1.0.2k/,然后重新 make && make install
相关推荐
睡不醒的猪儿6 小时前
nginx常见的优化配置
运维·nginx
root666/14 小时前
【后端开发-nginx】proxy_pass和proxy_redirect参数作用
运维·nginx
工具罗某人15 小时前
docker快速部署kafka
java·nginx·docker
最贪吃的虎18 小时前
Redis其实并不是线程安全的
java·开发语言·数据库·redis·后端·缓存·lua
864记忆1 天前
Qt创建连接注意事项
数据库·qt·nginx
Anarkh_Lee2 天前
别再手写 conf 了!NgxFlow:基于 React Flow 的 Nginx 可视化与调试神器
前端·nginx·数据可视化
Run Out Of Brain2 天前
解决nginx代理配置下wordpress的 /wp-admin/返回 302 重定向到登录页问题
运维·nginx
一勺菠萝丶2 天前
芋道项目部署:前端写死后端地址 vs Nginx 反向代理
前端·nginx·状态模式
_200_2 天前
Lua 流程控制
开发语言·junit·lua
Kang.Charles2 天前
Lua UI系统框架逻辑详解
ui·lua