具有入站http网关和出站http网关的Spring集成应用程序,在我想拥有缓存之间,以避免不必要的请求 . 我唯一的解决方案是添加拦截器缓存和路由器后,它将cahced结果路由回到回复通道,并且非缓存到出站,但这个解决方案对我来说似乎很棘手和丑陋 . 当入站网关具有相同的请求和回复通道时,具有缓存的拦截器也很有效(当返回具有相同标头但具有不同有效负载的新消息时,它被视为回复)但不是我可以使用的情况 .
对此更好的想法?
使用<request-handler-advice-chain>和Spring Cache Advice可以实现更优雅的解决方案 .
所以,你的解决方案可能是这样的:
<int-http:outbound-gateway> <int-http:request-handler-advice-chain> <cache:advice> <cache:caching cache="foo"> <cache:cacheable method="handle*Message" key="#a0.payload"/> </cache:caching> </cache:advice> </int-http:request-handler-advice-chain> </int-http:outbound-gateway>
其中 handle*Message 是 HttpRequestExecutingMessageHandler 的 handleRequestMessage 方法 . 正是对于这种方法,Spring Integration应用了他的建议(例如 RequestHandlerRetryAdvice ) .
handle*Message
HttpRequestExecutingMessageHandler
handleRequestMessage
RequestHandlerRetryAdvice
在这里,您应该配置 cacheManager bean,选择缓存名称并确定 key 用于缓存条目 . 在上面的示例中, #a0 是来自 handleRequestMessage 参数的 Message 对象 . 因此,您可以针对消息属性(有效负载和标头)指定任何SpEL表达式 . 并且 handleRequestMessage 的结果将存储在缓存中 .
cacheManager
key
#a0
Message
当您为HTTP reqeust提供相同的参数时,结果将仅从缓存返回 .
1 回答
使用<request-handler-advice-chain>和Spring Cache Advice可以实现更优雅的解决方案 .
所以,你的解决方案可能是这样的:
其中
handle*Message
是HttpRequestExecutingMessageHandler
的handleRequestMessage
方法 . 正是对于这种方法,Spring Integration应用了他的建议(例如RequestHandlerRetryAdvice
) .在这里,您应该配置
cacheManager
bean,选择缓存名称并确定key
用于缓存条目 . 在上面的示例中,#a0
是来自handleRequestMessage
参数的Message
对象 . 因此,您可以针对消息属性(有效负载和标头)指定任何SpEL表达式 . 并且handleRequestMessage
的结果将存储在缓存中 .当您为HTTP reqeust提供相同的参数时,结果将仅从缓存返回 .