guava-retrying重试工具库: AttemptTimeLimiter
2016-12-27 13:59
525 查看
AttemptTimeLimiter和guava的TimeLimiter基本是一样的,是为了限制某个任务的执行时间。比如我希望一个Callable任务执行时间不超过5s,如果超过抛异常TimeoutException。
import com.google.common.util.concurrent.SimpleTimeLimiter;
import com.google.common.util.concurrent.TimeLimiter;
import java.util.concurrent.Callable;
import java.util.concurrent.TimeUnit;
public class TestTimeLimiter {
public static void main(String[] args) throws Exception {
TimeLimiter timeLimiter = new SimpleTimeLimiter();
timeLimiter.callWithTimeout(buildTask(), 5, TimeUnit.SECONDS, false);
}
private static Callable<Boolean> buildTask() {
return new Callable<Boolean>() {
@Override
public Boolean call() throws Exception {
long start = System.currentTimeMillis();
long end = start;
while (end - start <= 10 * 1000) {
end = System.currentTimeMillis();
}
return true;
}
};
}
}
AttemptTimeLimiter功能与之类似,保证某次重试的执行时间不超过特定值。
public class TestLimit {
private static SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss,SSS");
public static void main(String[] args) throws Exception {
Retryer<Boolean> retryer = RetryerBuilder.<Boolean>newBuilder()
.retryIfException()
.retryIfResult(Predicates.equalTo(false))
.withAttemptTimeLimiter(AttemptTimeLimiters.fixedTimeLimit(1, TimeUnit.SECONDS))
.withStopStrategy(StopStrategies.stopAfterAttempt(5))
.build();
System.out.println("begin..." + df.format(new Date()));
try {
retryer.call(buildTask());
} catch (Exception e) {
System.err.println("still failed after retry." + e.getCause().toString());
}
System.out.println("end..." + df.format(new Date()));
}
private static Callable<Boolean> buildTask() {
return new Callable<Boolean>() {
@Override
public Boolean call() throws Exception {
System.out.println("called");
long start = System.currentTimeMillis();
long end = start;
while (end - start <= 10 * 1000) {
end = System.currentTimeMillis();
}
return true;
}
};
}
}
import com.google.common.util.concurrent.SimpleTimeLimiter;
import com.google.common.util.concurrent.TimeLimiter;
import java.util.concurrent.Callable;
import java.util.concurrent.TimeUnit;
public class TestTimeLimiter {
public static void main(String[] args) throws Exception {
TimeLimiter timeLimiter = new SimpleTimeLimiter();
timeLimiter.callWithTimeout(buildTask(), 5, TimeUnit.SECONDS, false);
}
private static Callable<Boolean> buildTask() {
return new Callable<Boolean>() {
@Override
public Boolean call() throws Exception {
long start = System.currentTimeMillis();
long end = start;
while (end - start <= 10 * 1000) {
end = System.currentTimeMillis();
}
return true;
}
};
}
}
AttemptTimeLimiter功能与之类似,保证某次重试的执行时间不超过特定值。
public class TestLimit {
private static SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss,SSS");
public static void main(String[] args) throws Exception {
Retryer<Boolean> retryer = RetryerBuilder.<Boolean>newBuilder()
.retryIfException()
.retryIfResult(Predicates.equalTo(false))
.withAttemptTimeLimiter(AttemptTimeLimiters.fixedTimeLimit(1, TimeUnit.SECONDS))
.withStopStrategy(StopStrategies.stopAfterAttempt(5))
.build();
System.out.println("begin..." + df.format(new Date()));
try {
retryer.call(buildTask());
} catch (Exception e) {
System.err.println("still failed after retry." + e.getCause().toString());
}
System.out.println("end..." + df.format(new Date()));
}
private static Callable<Boolean> buildTask() {
return new Callable<Boolean>() {
@Override
public Boolean call() throws Exception {
System.out.println("called");
long start = System.currentTimeMillis();
long end = start;
while (end - start <= 10 * 1000) {
end = System.currentTimeMillis();
}
return true;
}
};
}
}
相关文章推荐
- guava-retrying,重试工具使用
- guava-retrying重试工具库: 阻塞策略BlockStrategy
- guava-retrying重试工具库: RetryListener
- guava-retrying重试工具库: Retryer.call()使用注意事项
- guava-retrying重试工具库: 什么时候终止
- guava-retrying重试工具库: 什么时候重试
- guava-retrying重试工具库: 隔多长时间重试
- Spring错误异常重试框架guava-retrying
- Guava源码分析——Proxy模式(TimeLimiter)
- guava-retrying实现业务逻辑重试
- Guava中的基本类型工具
- iOS使用Instrument-Time Profiler工具分析和优化性能问题
- Guava RateLimiter在Web应用中的使用
- 分布式环境下限流方案的实现redis RateLimiter Guava,Token Bucket, Leaky Bucket
- Guava 2:Basic utilities基本工具
- 计算运行时间工具timeit
- 利用Apache工具和Guava对ArrayList进行分页
- python中计时工具timeit模块的基本用法
- Anuko time tracker 填报工具
- PING工具里的Byte= ` Time=` TTL=`代表的意思