通过OpenResty+Redis+MySQL+Lua脚本实现对首页轮播图的优化

本文介绍了如何通过OpenResty、Redis和MySQL结合Lua脚本来优化首页轮播图的加载速度。首先,通过添加Redis缓存减少数据库压力,然后演示了OpenResty连接Redis和MySQL的配置过程,最后讨论了Lua脚本在数据查询和缓存预热中的应用,以及前端Vue项目的部署和配置以实现跨域访问。
摘要由CSDN通过智能技术生成

 首先我们在没有使用任何的优化前提下,前端首页的响应时间大概在6秒钟,这在测试的人员看来,根据258原则,响应效率明显是有待提高的。这里简单的提一下什么是258原则:

2秒钟之内响应用户是非常好的。
2-5秒钟之内响应用户是可以接受的。
5-8秒钟是用户能接受的响应的上限。
>8秒钟是比较糟糕的,用户会选择离开这个Web站点或发起第二次请求。

我们6秒的响应时间已经岌岌可危了,因此需要进一步的优化;
第一次优化:加Redis缓存
优点:它的好处是减轻了数据库的并发压力,提高了查询的效率。
缺点:当然也有redis缓存的并发问题,这里就不细说了,见我的另一篇文章有详细的说明:Redsi缓存的并发问题。

大致的执行流程图:

绕过Tomcat 直接去OpenResty中的nginx缓存中获取数据,nginx先去redis缓存中读取;

这里更新缓存可以加一个socket编程方式去定时任务完成,就不具体说了。 

接下来说一下怎么使用OpenResty连接Redis服务和MySQL服务。

首先我们将Linux版本的Redis启动

进入Redis安装的src目录下 用启动命令启动服务:(带配置文件启动)

./redis-server ../redis.conf

 得到这个界面说明启动成功了

我们需要安装Lua;

Linux系统安装:

curl -R -O http://www.lua.org/ftp/lua-5.3.0.tar.gz
tar zxf lua-5.3.0.tar.gz
cd lua-5.3.0
make linux test
make install

这里就不多介绍Lua脚本了,接下来我们需要去已经安装好的OpenResty的Nginx目录的conf目录下新建一个lua文件夹;命令

mkdir lua

cd lua 进入文件夹 然后创建一个文件直接用 vim redis.lua 快捷新建文件

编写Lua脚本测试连接Redis

--测试连接redis的lua脚本
local redis = require "resty.redis"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值