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插件
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
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

你可能感兴趣的:(nginx,lua,nginx)