首页优化:通过openResty整合Lua脚本访问Redis

本文介绍了如何通过OpenResty结合Lua脚本优化首页加载,实现缓存预热和缓存读取。利用定时任务确保MySQL与Redis数据同步,达到1~2秒的响应时间。缓存分为内部缓存和Redis二级缓存,使用Lua脚本(ad_update.lua, ad_load.lua)进行操作,并展示了SpringBoot的定时任务配置。" 81014796,5748766,TCP通信与select函数详解,"['UNIX网络编程', 'select']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

         缓存预热

定时任务

缓存读取

优化整体框架图:

通过OpenResty整合Lua脚本访问Redis,直接将数据返回给前端页面。

分为二级缓存,内部缓存和Redis

缓存预热,定时任务实现MySQL和Redis的同步

响应时间达到1~2秒

主要分为两个步骤:

1.缓存预热

2.缓存读取

缓存预热

以首页轮播图为例,lua脚本内容如下:

将ad_update.lua保存到openresty/nginx/conf/lua目录下

ad_update.lua

-- 获得uri中的sid参数值
local uri_args = ngx.req.get_uri_args()
local sid = uri_args["sid"]
-- 连接mysql
local mysql = require "resty.mysql"
local db = mysql:new()
db:set_timeout(1000)
local ok, err = db:connect{
    host = "127.0.0.1",
    port = 3306,
    database = "edu_ad",
    user = "root",
    password = "123456",
    charset = "utf8"
}
if not ok then
    ngx.say("failed to connect: ", err)
    return
end
ngx.say("connected to mysql.")
-- 按区域编号查询轮播图表
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值