使用Lua + Nginx + Redis, 借助OpenResty应用于商城首页的高并发情况

Lua

lua是一个小巧的脚本语言,由标准C编写而成,几乎在所有操作系统和平台上都可以编译运行。其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。

应用场景:游戏开发、独立应用脚本、redis中嵌套调用实现类似事务的功能,web容器汇总处理NGINX的过滤缓存等等逻辑

 

OpenResty介绍

OpenResty是一个基于Nginx与Lua的高性能web平台,由中国人章亦春发起,其内部集成了大量精良的Lua库、第三方模块以及大多数的依赖项。用于方便搭建能处理超高并发、扩展性极高的动态Web应用、web服务和动态网关

OpenResty简单理解成就相当于封装了NGINX,并且集成了LUA脚本,开发人员只需要简单的使用其提供了模块就可以实现相关的逻辑,而不像之前,还需要在NGINX中编写lua的脚本。

 

 

网站首页分类列表缓存方案

用户发出/category/list的请求,查询的数据大概有这么多,下图的滚动条可以看出数据非常多。那我们如何保证首页访问的性能呢?

这是我们的解决方案:

1、使用Lua查询Nginx缓存,如果有缓存,则直接将缓存中的分类数据返回

2、如果Nginx缓存中没有分类数据,则通过Lua脚本查询Redis,如果Redis中有数据,则将数据存入到Nginx缓存中,并返回查询到的数据

3、如果Redis中也没有缓存,则此时通过Lua脚本查询Mysql,如果Mysql中有数据,将分类数据存入到Redis缓存,并返回数据

 

read_category.lua 的脚本文件

ngx.header.content_type = "application/json;charset=utf8"
local cache_ngx = ngx.shared.dis_cache;
local contentCache = cache_ngx:get("cl");
if contentCache == "" or contentCache == nil then
    local redis = require("resty.redis");
    local red = redis:new()
    red:set_timeout(2000)
    red:connect("192.168.220.110", 6379)
    local rescontent = red:get("cl");
    if ngx.null == rescontent then
        local cjson = require("cjson");
        local mysql = require("resty.mysql");
        local db = mysql:new();
        db:set_timeout(2000)
        local props = {
            host = "192.168.220.110",
            port = 3306,
            database = "legou",
            user = "root",
            password = "root"
        }
        local res = db:connect(props);
        local select_sql = "SELECT id_,is_parent_,order_,parent_id_,title_,expand_ FROM category_"
        res = db:query(select_sql);
        local responsejson = cjson.encode(res);
        red:set("cl", responsejson);
        ngx.say(responsejson);
        db:close()
        elsecache_ngx:set("cl", rescontent, 10 * 60);
        ngx.say(rescontent)
    end
    red:close()
    elsengx.say(contentCache)
end

 

在nginx.conf中配置

当访问 category/list请求时,openresty会将执行我们写好的read_category.lua脚本

访问测试:

查看redis

 

测试成功,当第一次访问/category/list时,会查询mysql数据库,然后将数据存储到redis中和 NGINX缓存中,当第二访问时,会直接从NGINX的缓存中取出数据,此时只要NGINX的服务不关闭,就算删除了redis中的数据,也没有影响。

 

提出一个问题:当我们修改了mysql数据库的信息,比如说做了增加删除的操作,我们怎么样把数据同步到redis中,如何反应给我们的NGINX缓存呢?下一篇文章介绍阿里的新技术canal

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你在狗叫什么、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值