nginx+lua+redis高并发应用建设

ngx_lua将lua嵌nginx,让nginx运行lua脚本。高并发,非堵塞过程中的各种请求。

url要求nginxserver,然后lua查询redis,返回json数据。

一.安装lua-nginx-module

參见《LNMLGC》架构

二.安装redis2-nginx-module模块

get https://github.com/openresty/echo-nginx-module

get https://github.com/openresty/redis2-nginx-module

get https://github.com/agentzh/set-misc-nginx-module.git

#

./configure --prefix=/usr/local/nginx   \

--with-debug                            \

--with-http_stub_status_module          \

--with-http_ssl_module                  \

--with-pcre=../pcre-8.21                \

--add-module=../ngx_devel_kit-0.2.19    \

--add-module=../lua-nginx-module-0.9.8  \

--add-module=../echo-nginx-module       \

--add-module=../redis2-nginx-module     \

--add-module=../set-misc-nginx-module

# make

# make install

三.安装lua-redis-parser

# git clone https:

//github.com/agentzh/lua-redis-parser.git

# export LUA_INCLUDE_DIR=/usr/local/include/luajit-2.0

# make CC=gcc

# make install CC=gcc

四.安装json

# wget http:

//files.luaforge.net/releases/json/json/0.9.50/json4lua-0.9.50.zip

# unzip json4lua-0.9.50.zip

# cp json4lua-0.9.50/json/json.lua /usr/local/lua/lib/

五.安装redis-lua

# git clone https:

//github.com/nrk/redis-lua.git

# cp redis-lua/src/redis.lua /usr/local/lua/lib/

六.配置

...
http {
    ...
    upstream redis_pool {
        server localhost:6379;
        keepalive 1024 single;
        //定义连接池大小,当连接数达到此数后。兴许的连接为短连接
    }
    server {
        ...
        location /get_redis{
            #internal;
            set_unescape_uri $key $arg_key;
            redis2_query hgetall $key;
            redis2_pass redis_pool;
        }
        location /json {
            content_by_lua_file conf/test.lua;
        }
    }
}

# vi test.lua,放在nginx.conf同文件夹下

local json = require("json")
local parser = require("redis.parser")
local res = ngx.location.capture("/get_redis",{
  args = { key = ngx.var.arg_key }
})
if res.status == 200 then
  reply = parser.parse_reply(res.body)
  value = json.encode(reply)
  ngx.say(value)
  a = json.decode(value)
  ngx.say(a[2])
end

七.測试

# redis-cli

127.0.0.1:6379> HMSET ttlsa www www.ttlsa.com mail mail.ttlsa.com

OK

127.0.0.1:6379> hgetall ttlsa

1) "www"

2) "www.ttlsa.com"

3) "mail"

4) "mail.ttlsa.com"

# curl http://localhost/json?

key=ttlsa

["www","www.ttlsa.com","mail","mail.ttlsa.com"]

www.ttlsa.com

时间: 2024-10-29 22:47:53

nginx+lua+redis高并发应用建设的相关文章

nginx+lua+redis构建高并发应用(转)

nginx+lua+redis构建高并发应用 ngx_lua将lua嵌入到nginx,让nginx执行lua脚本,高并发,非阻塞的处理各种请求. url请求nginx服务器,然后lua查询redis,返回json数据. 备注:centos或者redhat系统请跳转到nginx + ngx_lua安装测试 一.安装lua 1 2 3 # apt-get install lua5.1 # apt-get install liblua5.1-dev # apt-get install liblua5.

nginx+lua+redis构建高并发应用

ngx_lua将lua嵌入到nginx,让nginx执行lua脚本,高并发,非阻塞的处理各种请求. url请求nginx服务器,然后lua查询redis,返回json数据. 一.安装lua-nginx-module 参见<LNMLGC>架构 二.安装redis2-nginx-module模块 get https://github.com/openresty/echo-nginx-module get https://github.com/openresty/redis2-nginx-modul

nginx lua redis 访问频率限制(转)

1. 需求分析 Nginx来处理访问控制的方法有多种,实现的效果也有多种,访问IP段,访问内容限制,访问频率限制等. 用Nginx+Lua+Redis来做访问限制主要是考虑到高并发环境下快速访问控制的需求. Nginx处理请求的过程一共划分为11个阶段,分别是: post-read.server-rewrite.find-config.rewrite.post-rewrite. preaccess.access.post-access.try-files.content.log. 在openre

Nginx+Lua+Redis配置

想在Nginx上开发具有这样功能的一个转发模块,外部转发策略控制服务器将一些指定的URL发送给数据库,Nginx读取数据库中的URL列表,将列表指定的这些URL转发到特定的缓存代理服务器上,其他非数据库URL列表中的URL请求直接通过Nginx转发到出口网关上.实际上以上的功能就是很多网站利用Nginx做负载均衡时的实现的七层转发功能,不太一样的是,我想加一个外部的转发策略控制服务器将一些实时的URL列表发送给Nginx,这样如果这些URL信息是根据大数据处理结果统计出的最高热点访问URL,就可

nginx+lua+redis实现验证码防采集

之前介绍过在nginx里如何嵌入lua模块,利用nginx+lua可以很好的开发开发nginx的业务逻辑,并且达到高并发的效果. 下面我们就来介绍下利用nginx+lua+redis实现防采集的功能. 现象: 网站在为用户提供服务的同时也在被搜索引擎.采集器不断的抓取,可能会造成网站不堪重负,导致页面放回5XX错误.针对此种情况,我们就要对采集器及搜索引擎来进行访问控制,当然对搜索引擎的控制可能会影响网站的收录. 功能描述: nginx+lua在前端实现客户端的访问控制,将客户端的访问信息记入r

nginx+lua+redis(openresty)配置

nginx+lua+redis(openresty)配置 2014-07-18 11:10 2494人阅读 评论(1) 收藏 举报 方案一: 1.安装lua解释器 wget http://luajit.org/download/LuaJIT-2.0.2.tar.gz (http://luajit.org/download.html) 配置lua Lib和include/luajit-$version目录为环境变量 2.下载ngx_devel_kit和lua-nginx-module https:

Nginx+Lua+Redis 对请求进行限制

Nginx+Lua+Redis 对请求进行限制 一.概述 需求:所有访问/myapi/**的请求必须是POST请求,而且根据请求参数过滤不符合规则的非法请求(黑名单), 这些请求一律不转发到后端服务器(Tomcat) 实现思路:通过在Nginx上进行访问限制,通过Lua来灵活实现业务需求,而Redis用于存储黑名单列表. 相关nginx上lua或redis的使用方式可以参考我之前写的一篇文章: openresty(nginx).lua.drizzle调研 http://www.cnblogs.c

nginx+php+redis vs nginx+lua+redis

最近在做通知系统,前端用的轮询方式(后端压力不小),因为时间比较紧,开始我准备把未读通知标识存在数据库中,但是每次拿数据的时候需要查询一遍数据库,总监说你这样效率较低,说你可以根据用户id作为key放在redis中存储.说说自己在做这个的一些体会和闲下来总结的一些笔记. phpredis connect pconnect 我最开始使用的是connect,每次请求完毕关闭连接 1 <?php 2 $redis = new Redis(); 3 $nError = $redis->connect(

nginx、swoole高并发原理初探

原文:https://segmentfault.com/a/1190000007614502 一.阅前热身 为了更加形象的说明同步异步.阻塞非阻塞,我们以小明去买奶茶为例. 1.同步与异步 ①同步与异步的理解 同步与异步的重点在消息通知的方式上,也就是调用结果通知的方式. 同步当一个同步调用发出去后,调用者要一直等待调用结果的通知后,才能进行后续的执行 异步:当一个异步调用发出去后,调用者不能立即得到调用结果的返回. 异步调用,要想获得结果,一般有两种方式:1.主动轮询异步调用的结果;2.被调用