使用注解实现Hystrix请求缓存

Hystrix提供3个专用的请求缓存注解:

@CacheResult——该注解用来标记请求命令返回的结果应该被缓存,必须与@HystrixCommand注解结合使用,属性:cacheKeyMethod

@CacheRemove——该注解使请求命令的缓存失效,失效的缓存根据定义的Key决定,属性:commandKey,cacheKeyMethod

@CacheKey——该注解用来在请求命令的参数上标记,使其作为缓存的Key值,如果没有标注则会使用所有的参数。如果同时还使用了@CacheResult和@CacheRemove注解的cacheKeyMethod方法指定缓存Key的生成,那么该注解将不起作用,属性:value

实例

使用@CacheResult设置请求缓存,在不指定缓存Key的情况下,缓存Key会使用所有的参数(本例中的Long类型id值):

由于要使用Hystrix的请求缓存,必须要先初始化一个HystrixRequestContext实例,也就是说Hystrix请求缓存必须在HystrixRequestContext中才起作用。所以要自定义一个webfilter,将请求放入到HystrixRequestContext中,具体代码如下:

然后,在Spring Application上加上:

服务提供端接口代码如下(每调一次该接口,都生成一个随机数及打印系统时间,来测试客户端调用是否走的缓存):

测试发现,每次客户端每次调用还是没有走缓存(请求id都一样),原因是当在客户端controller里面响应请求时,每一次请求都会有自己独立的线程和ServletContext,而Hystrix请求缓存要求请求必须在同一个HystrixRequestContext中。每一个HystrixReqeustContext都有自己本地线程变量来维护缓存(Map结构),不同的HystrixRequestContext维护的缓存不一样,不能交叉访问。可以在同一个controller里面调两次HelloService来测试缓存是否有效:

从结果中,可以看到缓存起作用了(随机数一样并且服务提供端接口只被调用一次):

移除缓存(@CacheRemove),代码如下:

controller里面测试代码:

从结果上看前两次缓存是有效的,当update后,该id的缓存已经清楚,所以第三次(str3)调用就不走缓存了:

如果使用@CacheKey("id"),会报java.beans.IntrospectionException: Method not found: isId,目前还不知道什么原因。

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,100评论 18 139
  • (git上的源码:https://gitee.com/rain7564/spring_microservices_...
    sprainkle阅读 9,225评论 13 33
  • iOS网络架构讨论梳理整理中。。。 其实如果没有APIManager这一层是没法使用delegate的,毕竟多个单...
    yhtang阅读 5,098评论 1 23
  • 前言 主题是Mybatis一级和二级缓存的应用及源码分析。希望在本场chat结束后,能够帮助读者朋友明白以下三点。...
    余平的余_余平的平阅读 1,271评论 0 12
  • 最近作息很紊乱… 刚刚处理完数据… 老年音乐家的优势终于在数据上显示出来了,虽然才收了一半的数据,不过甚感欣慰。 ...
    傅五岁阅读 141评论 0 0