我正在尝试为我的服务设计操作超时逻辑。每个操作与多个下游服务进行交互(同步和异步)。目的是能够在一定时间后终止操作,而不管状态如何。
解决方案中是否有可以利用的设计模式?
答案 0 :(得分:0)
您可以使用Future访问下游服务,然后使用某种事件驱动的方法来处理成功/超时。
public interface ICallback {
public void onSuccess(DsObject object);
public void onTimeout();
}
访问下游服务的方式可能如下所示:
public class DownstreamConnector implements Callable<DsObject> {
@Override
public DsObject call() {
// Invoke your downstream services here
return ...
}
}
然后,您可以将可调用对象包装在Future<>
周围,以调用下游服务并检查超时。
final ICallback callback = new MyCallbackHandler();
final DownstreamConnector connector = new DownstreamConnector()
ExecutorService executor = ...
Future<DsObject> future = executor.submit(connector);
try {
DsObject result = future.get(TIMEOUT, TimeUnit.MILISECONDS);
// Operation completed
callback.onSuccess(result);
} catch (TimeoutException ex) {
logger.error("Operation timed out", ex);
future.cancel(true);
// Timed out
callback.onTimeout();
}
仅提供注释:
future.cancel(true);
不会不停止正在运行的基础任务,它只是将正在运行的线程的interrupted标志设置为true。是由您的代码负责检查此标志并抛出InterruptedException
(如果为真)。