实现超时的设计模式

时间:2019-02-18 07:33:15

标签: design-patterns

我正在尝试为我的服务设计操作超时逻辑。每个操作与多个下游服务进行交互(同步和异步)。目的是能够在一定时间后终止操作,而不管状态如何。

解决方案中是否有可以利用的设计模式?

1 个答案:

答案 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(如果为真)。