分布式二级缓存组件

简介

分布式二级缓存组件,本地缓存支持二级,远端控制协调版本,可避免集中式缓存的IO开销,尤其是在异地部署同一个应用时候,能避免跨区域通信,提高缓存时效和可用性;

适用场景

1、当参数(业务参数、系统参数)需要被多个应用实例进行缓存到本地时候,可以使用本组件;
2、单个应用云上分布式部署时候,需要保证各个实例缓存的参数都要最新,可以使用本组件;

架构设计

关键设计

数据结构:Map<String, List<Map<String, Object>>>,两个String分别存储表名和字段名。
版本号:用于解决多个工程之间,数据一致性问题。
Cache:控制手动或定时刷新缓存;提供接口,通过表名获取数据;提供接口,通过字段过滤数据;提供二级缓存,数据查询后存入二级缓存,下次查询更加快捷。
Redis:用于和Redis数据库交互,获取或更新版本信息;提供锁机制,保证多个工程之间更新版本信息时互不影响。
acc-params-query:提供数据查询接口,数据结构Map<String, List<Map<String, Object>>>


xxx.png

交互方式

第一步:当数据库数据更新时,需通知Redis数据库,更新远程版本号(使用唯一的key值,一般使用工程名、系统名、类型等拼接组成)。
第二步:缓存组件定时(或手动)向Redis数据库获取远程版本号,和本地版本号进行对比,若版本相同,则说明本地数据为最新数据,无需更新;若本地版本与远程版本不同,则需更新本地数据,缓存会向数据请求接口发送获取数据请求,返回最新数据存入本地缓存,同时清空二级缓存。
第三步:主工程(父容器)向缓存组件发起查询请求后,缓存组件根据查询条件(表名、字段名等)首先到二级缓存查询对应数据,如果有相应的数据,则直接返回;若无相应数据,则到本地缓存中获取相应数据后返回,并将该数据写入二级缓存。

Maven依赖

 <!--依赖缓存组件,加载缓存数据-->
 <dependency>
    <groupId>com.xxx.cache</groupId>
    <artifactId>tw-cache</artifactId>
    <version>1.0.0-SNAPSHOT</version>
 </dependency>

配置信息

# 产品名称  
zcRedis.key.productCode=xxx
# 系统名称  
zcRedis.key.systemName=cache
# 系统名(用于区分使用缓存组件的各个系统) 
cache.system.name=xxx
# accParams
# 查询服务地址,通过系统名获取对应若干张表数据
cache.paramServer.url=http://xxx/xxx/queryCashData
# 定时任务
cache.refresh.job.schedule=0 0/5 * * * ?

接口

常用接口有:
1、获取当前类型的所有参数
List<T> getParamList(Class<T> paramClass)
2、根据条件返回单个对象
T getParamObject(Class<T> paramClass, Map<String, Object> filters)
3、获取当前类型的所有参数,优先走本地二级缓存
List<T> getParamList(Class<T> paramClass, Map<String, Object> filters)

使用示例

List<Map<String,Object>> tableData = ParamsCache.getParamList(GlobalKeyEnum.T_OUTMAP_INF.getTableName(),hashMap);
....
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,589评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,615评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,933评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,976评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,999评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,775评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,474评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,359评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,854评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,007评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,146评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,826评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,484评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,029评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,153评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,420评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,107评论 2 356