如何解决使用resilience4j实现节流/去抖动
我的问题是如何使用resilience4j 库实现(配置)throttlig。 我尝试在下一个配置中使用 RateLimiter:
RateLimiter rateLimiter = RateLimiterRegistry.of(
RateLimiterConfig.custom()
.limitRefreshPeriod(Duration.ofSeconds(10))
.limitForPeriod(1)
.timeoutDuration(Duration.ofSeconds(5))
.build()
).rateLimiter("default");
Runnable ratedCall = RateLimiter.decorateRunnable(rateLimiter,() -> { /*business logic here*/ });
// and then
try {
ratedCall.run();
} catch (Exception e) {
LOG.warn(e);
}
但它不会阻止(忽略)后续的方法调用。 我需要实现的是,无论任何可能的异常,我的特定方法都不能在 10 秒内被多次调用一次。
请多多指教!
谢谢!
解决方法
解决办法是设置超时时间为0:
timeoutDuration(Duration.ofSeconds(0))
回答https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/RunLambdaSchedule.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。