nginx安装lua+redis

Posted Json2011315

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx安装lua+redis相关的知识,希望对你有一定的参考价值。

1.安装lua

1.1安装LuaJIT

[root@localhost ~]# yum install readline-devel
[root@localhost ~]# mkdir -p lua-file
[root@localhost ~]# cd lua-file/
[root@localhost lua_file]# wget http://luajit.org/download/LuaJIT-2.0.5.tar.gz
[root@localhost lua_file]# tar -zxvf LuaJIT-2.0.5.tar.gz 
[root@localhost lua_file]# ls
LuaJIT-2.0.5  LuaJIT-2.0.5.tar.gz
[root@localhost lua_file]# cd LuaJIT-2.0.5
[root@localhost LuaJIT-2.0.5]# make && make install PREFIX=/usr/local/luajit

1.2配置LuaJIT环境变量

[root@localhost lua-file]# vim /etc/profile

#/etc/profile 文件中加入环境变量
export LUAJIT_LIB=/usr/local/luajit/lib
export LUAJIT_INC=/usr/local/luajit/include/luajit-2.0

[root@localhost lua-file]# source /etc/profile

1.3 lua安装测试

[root@localhost lua-file]# vim hello.lua
print('hello world lua');

[root@localhost lua-file]# lua hello.lua 
hello world lua

2.ngx_devel_kit和lua-nginx-module

ngx_devel_kit简称NDK,提供函数和宏处理一些基本任务,减轻第三方模块开发的代码量。
lua-nginx-module是nginx的lua模块

[root@localhost ~]# mkdir -p /usr/local/src/nginx
[root@localhost ~]# cd /usr/local/src/nginx/
[root@localhost nginx]# wget https://github.com/simpl/ngx_devel_kit/archive/v0.3.0.tar.gz
[root@localhost nginx]# wget https://github.com/openresty/lua-nginx-module/archive/v0.10.9rc7.tar.gz
[root@localhost nginx]# ls
v0.10.9rc7.tar.gz  v0.3.0.tar.gz
[root@localhost nginx]# tar -zxvf v0.10.9rc7.tar.gz 
[root@localhost nginx]# tar -zxvf v0.3.0.tar.gz 

3.查看已安装好的nginx

3.1查看原安装

[root@localhost nginx]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.14.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) 
built with OpenSSL 1.0.2k-fips  26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/usr/local/nginx --with-pcre --with-http_ssl_module --with-http_gzip_static_module


3.2 安装依赖

[root@localhost nginx]# yum -y install openssl openssl-devel zlib zlib-devel pcre-devel

3.3 进入nginx解压目录,安装扩展

[root@localhost ~]# cd nginx-1.14.2
[root@localhost nginx-1.14.2]# 

3.3.1.清空之前的编译文件

[root@localhost nginx-1.14.2]# make clean

3.3.2 执行 nginx -V 查看之前的编译参数

[root@localhost nginx-1.14.2]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.14.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) 
built with OpenSSL 1.0.2k-fips  26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/usr/local/nginx --with-pcre --with-http_ssl_module --with-http_gzip_static_module

3.3.3 添加扩展执行编译

[root@localhost nginx-1.14.2]# ls /usr/local/src/nginx/
lua-nginx-module-0.10.9rc7  ngx_devel_kit-0.3.0  v0.10.9rc7.tar.gz  v0.3.0.tar.gz
[root@localhost nginx-1.14.2]# ./configure --prefix=/usr/local/nginx --with-pcre --with-http_ssl_module --with-http_gzip_static_module --add-module=/usr/local/src/nginx/lua-nginx-module-0.10.9rc7/ --add-module=/usr/local/src/nginx/ngx_devel_kit-0.3.0/

3.3.4.执行make (不能执行 make install)

[root@localhost nginx-1.14.2]# make

3.3.5.(打开新连接窗口操作)重命名 nginx 旧版本二进制文件,即 sbin 目录下的 nginx(期间 nginx 并不会停止服务)

客户端2
[root@localhost nginx-1.14.2]# cd /usr/local/nginx/sbin/
[root@localhost sbin]# ls
nginx
[root@localhost sbin]# mv nginx nginx.old
[root@localhost sbin]# ls
nginx.old

3.3.6.拷贝一份新编译的二进制文件到安装目录

[root@localhost nginx-1.14.2]# pwd
/root/nginx-1.14.2
[root@localhost nginx-1.14.2]# cd objs/
[root@localhost objs]# ll
total 9124
drwxr-xr-x. 3 root root      17 Nov 16 22:55 addon
-rw-r--r--. 1 root root   18837 Nov 16 22:55 autoconf.err
-rw-r--r--. 1 root root   68709 Nov 16 22:55 Makefile
-rwxr-xr-x. 1 root root 9132336 Nov 16 22:57 nginx
-rw-r--r--. 1 root root    5341 Nov 16 22:57 nginx.8
-rw-r--r--. 1 root root    7493 Nov 16 22:55 ngx_auto_config.h
-rw-r--r--. 1 root root     657 Nov 16 22:55 ngx_auto_headers.h
-rw-r--r--. 1 root root    6209 Nov 16 22:55 ngx_modules.c
-rw-r--r--. 1 root root   86808 Nov 16 22:57 ngx_modules.o
drwxr-xr-x. 9 root root      91 Nov 16 22:55 src
[root@localhost objs]# cp nginx /usr/local/nginx/sbin/
[root@localhost objs]# ls /usr/local/nginx/sbin/
nginx  nginx.old


3.3.7.在源码目录执行 make upgrade 开始升级

[root@localhost nginx-1.14.2]# make upgrade
/usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`
sleep 1
test -f /usr/local/nginx/logs/nginx.pid.oldbin
kill -QUIT `cat /usr/local/nginx/logs/nginx.pid.oldbin`

###查看是否安装成功
[root@localhost nginx-1.14.2]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.14.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC) 
built with OpenSSL 1.0.2k-fips  26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/usr/local/nginx --with-pcre --with-http_ssl_module --with-http_gzip_static_module --add-module=/usr/local/src/nginx/lua-nginx-module-0.10.9rc7/ --add-module=/usr/local/src/nginx/ngx_devel_kit-0.3.0/


启动nginx,如果有这个报错:nginx: error while loading shared libraries: libluajit-5.1.so.2: cannot open shared object file: No such file or directory

#解决方案
[root@localhost nginx-1.14.2]# vim /etc/ld.so.conf
#新增一条
 /usr/local/luajit/lib

#保存文件,执行ldconfig 	
[root@localhost nginx-1.14.2]# ldconfig

4 nginx引入lua调试

4.1 nginx.conf引入lua

[root@localhost conf]# pwd
/usr/local/nginx/conf
[root@localhost conf]# vim nginx.conf

	#关闭代码缓存 。修改lua脚本不需要重启
    lua_code_cache off;

	 #测试lua
    server 
        listen 81;
        server_name localhost;

        #设置变量
        set $test "hello world lua";
        location /lua_test 
                content_by_lua '
                        ngx.header.content_type="text/plain";
                        ngx.say(ngx.var.test);
                ';
        
    

4.2 重启nginx,执行访问

[root@localhost nginx]# killall nginx
[root@localhost nginx]# /usr/local/nginx/sbin/nginx
nginx: [alert] lua_code_cache is off; this will hurt performance in /usr/local/nginx/conf/nginx.conf:22


浏览器执行访问:

5.实现lua连接redis

redis集群扩展包:https://github.com/onlonely/lua-redis-cluster
对于lua来说,它是一个非常轻量级的脚本语言,而它本身也与php的composer是一样的,是可以添加扩展,只是他们的扩展我们需要自己找对应的模块库
官方组件:https://openresty.org/cn/components.html

5.1 下载lua-redis-cluster(连接redis-cluster集群) 客户端

[root@localhost 5.1]# pwd
/usr/local/luajit/share/lua/5.1
[root@localhost 5.1]# git clone https://github.com/onlonely/lua-redis-cluster.git
[root@localhost 5.1]# ls
lua-redis-cluster

5.2 下载快速JSON编码/解析

[root@localhost 5.1]# git clone https://github.com/openresty/lua-cjson.git
[root@localhost 5.1]# ls
lua-cjson  lua-redis-cluster
[root@localhost 5.1]# 

5.3 下载 lua-resty-redis (单机版redis)客户端

[root@localhost 5.1]# git clone https://github.com/openresty/lua-resty-redis
[root@localhost 5.1]# ls
lua-cjson  lua-redis-cluster  lua-resty-redis

5.4 lua连接单机版本redis

资料地址:https://github.com/openresty/lua-resty-redis

5.4.1编辑nginx.conf脚本

	#关闭代码缓存 。修改lua脚本不需要重启
    lua_code_cache off;
    #引入lua-reds 扩展库(此处可以在lua脚本里面引入,公共的也可以在此引入)
    lua_package_path "/usr/local/luajit/share/lua/5.1/lua-resty-redis/lib/?.lua;;";

    #连接单机版本的redis
    server 
        listen 82;
        server_name localhost;
        location /lua_redis 
             default_type 'application/x-javascript;charset=utf-8';
             #引入redis
             #content_by_lua_file /usr/local/nginx/conf/lua/lua_test.lua;               
             content_by_lua_file /usr/local/nginx/conf/lua/lua_redis.lua;
        
    

截图nginx.conf:

5.4.2 编辑连接redis的lua脚本

[root@localhost conf]# vim lua/lua_redis.lua 

--引入redis扩展包
package.path ="/usr/local/luajit/share/lua/5.1/lua-resty-redis/lib/?.lua;;"

local redis = require "resty.redis"
local red = redis:new()

red:set_timeouts(1000, 1000, 1000) -- 1 sec

--lua 连接redis
local ok,err = red:connect("127.0.0.1", 6379)

if not ok then
       ngx.say("failed to connect: ", err)
       return
end


--设置数据
local date=os.date("%Y-%m-%d %H:%M:%S")
ok,err = red:set("dog", date.."-数据")
if not ok then
       ngx.say("failed to set dog: ", err)
       return
end


--获取设置的值
local res,err=red:get("dog")
if not res then
	ngx.say("failed to get dog",err)
	return
end

ngx.say(res)

截图lua_redis.lua :

5.4.3 重启nginx,访问nginx,数据成功写入redis,并读取

[root@localhost lua]# /usr/local/nginx/sbin/nginx -s reload

#(重启报错,自行查看nginx 的 error.log文件,具体根据自行的错误日志输错文件目录查看)
[root@localhost lua]# ls /usr/local/nginx/logs/
access.log  error.log

5.5 lua连接redis-cluster 集群

资料地址:
https://github.com/onlonely/lua-redis-cluster (以下demo使用该资源)
https://github.com/steve0511/resty-redis-cluster

5.5.1自行准备redis-cluster集群

5.5.2 编写连接redis-cluster的lua脚本

[root@localhost conf]# vim lua/lua_redis_cluster.lua

--引入redis-cluster扩展包
--package.path ="/usr/local/luajit/share/lua/5.1/lua-redis-cluster/?.lua;;/usr/local/luajit/share/lua/5.1/lua-resty-redis/lib/?.lua;;"
package.path ="/usr/local/luajit/share/lua/5.1/lua-redis-cluster/?.lua;;"


ngx.header.content_type="text/plain"
-- 构建redis集群
local function redis_cluster_init ()
    local redis_cluster = require "resty.redis_cluster"
    local cluster_id = "redis_cluster"
    local startup_nodes = 
        "192.168.11.124",6391,
		"192.168.11.124",6392,
		"192.168.11.124",6393,
		"192.168.11.124",6394,
		"192.168.11.124",6395,
		"192.168.11.124",6396,
    
    local opt = 
    	  timeout = 1000,--执行超时时间
    	  keepalive_size = 50,--长连接数量
        keepalive_duration = 60000 --长连接保持时间
    
    rc = redis_cluster:new(cluster_id, startup_nodes, opt)
    return rc
end
local redis = redis_cluster_init();
--调用API获取数据
--设置商品库存
local key = "goods_stock_12"
local res, err = redis:set(key,100)
if not res then
    ngx.say("set msg error : ", err)
end

--获取商品库存
local stock, err = redis:get(key)
if not stock then
    ngx.say("get msg error : ", err)
end
--得到的数据为空处理
if stock == ngx.null then
    stock = 0  --比如默认值
end
ngx.say("goods stock : ", stock)

截图lua_redis_cluster.lua:

5.5.3 lua-redis-cluster 模块存在问题,需要修改底层源码

[root@localhost resty]# pwd
/usr/local/luajit/share/lua/5.1/lua-redis-cluster/resty
#修改此文件
[root@localhost resty]# vim redis_cluster.lua

#修改的方法
function _M.initialize(self)
		....
		--替换此处代码
				 if addr_str == ":0" then
                    addr =  node[1],
                             tonumber(node[2]),
                             node[1] .. ":" .. tostring(node[2]) 
                else
                    local host_port = string_split(addr_str, ":", 2)
                    local ports = string_split(host_port[2], "@", 2)
                    addr =  host_port[1],
                             tonumber(ports[1]),
                             addr_str 
                end
		....
end

截图提示redis_cluster.lua:

5.5.4 重启nginx,浏览器访问,数据成功写入redis-cluster集群

以上是关于nginx安装lua+redis的主要内容,如果未能解决你的问题,请参考以下文章

nginx安装lua+redis

nginx安装lua+redis

nginx中使用lua操作redis数据库

Nginx + Lua + redis (转)

Nginx+Lua+Redis 实现高性能缓存数据读取

技术无边界 | Nginx+lua+Redis实现禁止黑名单访问