Nginx + Redis:高性能缓存利器

2年前 (2022) 程序员胖胖胖虎阿
172 0 0

一. OpenResty

OpenResty是一个基于 Nginx与 Lua的高性能 Web平台,其内部集成了大量精良的 Lua库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态Web 应用、Web 服务和动态网关。
接入层缓存技术就是使用OpenResty的技术用Lua语言进行二次开发。
Nginx + Redis:高性能缓存利器


二. Nginx + redis

下图左边是常用的架构,http请求经过nginx负载均衡转发到tomcat,tomcat再从redis读取数据,整个链路过程是串行的,当tomcat挂掉或者tomcat线程数被消耗完,就无法正常返回数据。
使用OpenResty的lua-resty-redis模块使nginx具备直接访问redis的能力,不占用tomcat线程,Tomcat暂时挂掉仍可正常处理请求,减少响应时长,提高系统并发能力。
Nginx + Redis:高性能缓存利器

三. 压缩减少带宽

数据大于1K,nginx压缩再保存到redis:
  • 提高redis的读取速度

  • 减少带宽的占用

压缩会消耗cpu时间,小于1K的数据不压缩tps更高。
OpenResty并没有提供redis连接池的实现,需要自己用lua实现redis的连接池,在网上已有实现的例子
http://wiki.jikexueyuan.com/project/openresty/redis/out_package.html
,直接参照使用。
Redis的value值用json格式保存
{length:xxx,content:yyy}
,content是压缩后的页面内容,length是content压缩前的大小,length字段是为了在读取redis时,根据length的大小来判断是否要解压缩content的数据。
使用lua-zlib库进行压缩。
Nginx + Redis:高性能缓存利器

四. 定时更新

按下图第1和第2步定时执行,nginx lua定时器定时请求tomcat页面的url,返回的页面html保存在redis。
缓存有效期可设置长些,比如1个小时,可保证1个小时内tomcat挂掉,仍可使用缓存数据返回,缓存的定时更新时间可设置短些,比如1分钟,保证缓存快速更新
Nginx + Redis:高性能缓存利器

五.请求转发

浏览器打开页面:
  • nginx先从redis获取页面html

  • redis不存在数据时,从tomcat获取页面,同时更新redis

  • 返回页面HTML给浏览器

Nginx + Redis:高性能缓存利器

六.  单进程定时更新

Nginx的所有worker进程都可以处理前端请求转发到redis,只有nginx worker 0才运行定时任务定时更新redis,lua脚本中通过
ngx.worker.id()
获取worker进程编号。

Nginx + Redis:高性能缓存利器


七 . 可配置化

通过管理后台配置需要缓存的URL,可配置缓存URL、缓存有效期、定时更新时间,比如
modify?url=index&&expire=3600000&&intervaltime=300000&sign=xxxx
,sign的值是管理后台secretkey对
modify?url=index&&expire=3600000&&intervaltime=300000
签名运算得到的,nginx端用相同的secretkey对
modify?url=index&&expire=3600000&&intervaltime=300000
签名运算,得到的值与sign的值相同则鉴权通过,允许修改nginx的配置。

Nginx + Redis:高性能缓存利器

来源:blog.csdn.net/phil_code/article/details/79154271

如果看到这里,说明你喜欢这篇文章,请 转发、点赞。微信搜索「web_resource」,关注后回复「进群」或者扫描下方二维码即可进入无广告交流群。

↓扫描二维码进群↓
Nginx + Redis:高性能缓存利器

推荐阅读
1.  GitHub 上有什么好玩的项目?
2.  Linux 运维必备 150 个命令汇总
3.  SpringSecurity + JWT 实现单点登录
4. 100 道 Linux 常见面试题
Nginx + Redis:高性能缓存利器

本文分享自微信公众号 - Java后端(web_resource)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

版权声明:程序员胖胖胖虎阿 发表于 2022年9月5日 下午11:32。
转载请注明:Nginx + Redis:高性能缓存利器 | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...