Skip to content

lijiefeng-lee/openresty-lua

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

结合 openresty 搭建多级缓存架构 Image

lru 缓存和 字典缓存 Image

Image

openresty可以利用lua-resty-lock 加锁,利用的是OpenResty 自带的 resty 库,它底层是基于共享字典,提供非阻塞的 lock API lua-resty-lock 的实现中,你需要自己来处理加锁、解锁、获取过期数据、重试、异常处理等各种问题,还是相当繁琐的 我们可以使用lua-resty- mlcache 加锁

Image

Redis集群 机器规划 容器名称 容器IP地址 映射端口号 服务运行模式 Redis-master1 172.50.0.2 "6391 -> 6397 16391 -> 16397" Master Redis-master2 172.50.0.3 "6392 -> 6397 16392 -> 16397" Master Redis-master3 172.50.0.4 "6393 -> 6397 16393 -> 16397" Master redis-slave1 172.30.0.2 "6394 -> 6397 16394 -> 16397" Slave redis-slave2 172.30.0.3 "6395 -> 6397 16395 -> 16397" Slave redis-slave3 172.30.0.4 "6396 -> 6397 16396 -> 16397" Slave

容器IP地址 映射端口号 服务运行模式 172.50.0.5 8001 -> 80 Nginx分发层 172.50.0.6 8002 -> 80 Nginx应用层 172.30.0.5 8003 -> 80 Nginx应用层

nginx分发层到应用层 加载lua包,使用lua编写的分发策略,让请求转发到应用层

lua定时获取consul当中的redis地址信息

curl -X PUT -d '47.98.147.49:6391' http://127.0.0.1:8501/v1/kv/redis_cluster/5

Key=》value redis_cluster/1=>47.98.147.49:6391

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published