guava-retrying重试工具库: 阻塞策略BlockStrategy
来源:互联网 发布:http tcp网络协议 编辑:程序博客网 时间:2024/06/04 19:22
什么是阻塞策略呢?通过前面的学习,我们知道guava-retrying是可以设置2次重试的时间间隔的。比如第一次失败后,需要等待200ms再开始第二次尝试,也就是说线程需要等待200ms。实现200ms等待有多种方式,比如通过sleep方式,比如通过自旋的方式,比如锁、wait等多种控制手段,这其实就是并发策略。guava-retrying默认是使用睡眠方式来实现阻塞的。
比如下面这段代码,我们配置的是重试5次,但是实际上只重试2次就会终止。因为我们将重试线程中断了,所以就不会再重试了。通过睡眠实现阻塞的一个好处:可以响应外部中断请求。
import com.github.rholder.retry.*;import java.util.concurrent.Callable;import java.util.concurrent.TimeUnit;public class TestBlock { private static Callable<Boolean> alwaysExceptionTask = new Callable<Boolean>() { @Override public Boolean call() throws Exception { System.out.println("called"); throw new NullPointerException(); } }; public static void main(String[] args) throws Exception { Thread retryThread = runInNewThread(); // 让retryThread先执行 Thread.sleep(2000); retryThread.interrupt(); } // 第一次重试是立刻执行的,无需等待 private static Thread runInNewThread() { Runnable runnable = () -> { Retryer<Boolean> retryer = RetryerBuilder.<Boolean>newBuilder() .retryIfException() .withBlockStrategy(BlockStrategies.threadSleepStrategy()) .withWaitStrategy(WaitStrategies.fixedWait(1, TimeUnit.SECONDS)) .withStopStrategy(StopStrategies.stopAfterAttempt(5)) .build(); try { retryer.call(alwaysExceptionTask); } catch (Exception e) { System.err.println("still failed after retry." + e.getCause().toString()); } }; Thread retryThread = new Thread(runnable); retryThread.start(); return retryThread; }}
我们可以自己实现阻塞策略,比如通过自旋来实现阻塞,那么就不会响应阻塞;比如我们实现一个假的阻塞策略(根本不阻塞),那么等待时间就没有意义了。
// 类似自旋锁的实现, 不响应线程中断public class SpinBlockStrategy implements BlockStrategy { @Override public void block(long sleepTime) throws InterruptedException { long start = System.currentTimeMillis(); long end = start; System.out.println("[SpinBlockStrategy]...begin wait."); while (end - start <= sleepTime) { end = System.currentTimeMillis(); } System.out.println("[SpinBlockStrategy]...end wait."); }}
import com.github.rholder.retry.BlockStrategy;// 伪造的阻塞策略,实际上根本没有任何阻塞public class FakeBlockStrategy implements BlockStrategy { @Override public void block(long sleepTime) throws InterruptedException { System.out.println("[FakeBlockStrategy]...begin wait."); System.out.println("[FakeBlockStrategy]...end wait."); }}
0 0
- guava-retrying重试工具库: 阻塞策略BlockStrategy
- guava-retrying重试工具库: 什么时候重试
- guava-retrying重试工具库: 什么时候终止
- guava-retrying重试工具库: RetryListener
- guava-retrying重试工具库: AttemptTimeLimiter
- guava-retrying重试工具库: 隔多长时间重试
- guava-retrying,重试工具使用
- guava-retrying重试工具库: Retryer.call()使用注意事项
- 【Guava】基于guava的重试组件Guava-Retryer
- 失败重试策略
- 弹性和瞬态故障处理库Polly之重试策略
- java重试工具库: 实现业务逻辑与重试逻辑的解耦
- Volley超时重试策略_RetryPolicy
- 【Jsoup in action】模拟浏览器:Jsoup工具类的使用及失败重试的retry策略(三)
- android初学------ volley学习-重试请求策略
- Azure Storage Client Library 重试策略建议
- 重温Volley源码(二):重试策略
- google工具类guava
- 考研英语 - word-list-2
- 深入理解Spark 2.1 Core (一):RDD的原理与源码分析
- Udacity自动驾驶课程笔记(一)
- 4010: [HNOI2015]菜肴制作
- presto源码分析(PartitionedOutputOperator)
- guava-retrying重试工具库: 阻塞策略BlockStrategy
- linux内核杂事记录
- STM32实现IIR工频陷波器
- TEC1701.WebADI开发技术总结 - 第四章 Web ADI相关后台表结构(4/6)
- 自定义动态表情键盘(简单,低耦合,可以更换动态表情)
- linux-FTP服务常用命令及测试
- Java中String类的方法及说明
- 53.自定义View练习(一)圆形百分比控件
- Android Cursor自动更新的实现和原理