如何解决如何在不使用任何额外线程的情况下使当前正在运行的 API 调用超时?
我从一个星期以来一直在寻找这个问题的答案,找不到任何相关的东西。终于决定在这里发帖了。
我有用例,我需要为不同的 API 调用提供自定义超时。这个用例听起来很常见。对 ?好吧,我想在不使用任何额外线程的情况下实现这一点。我正在寻找如下所述的系统时钟。
所以基本上,我想写一个方法(调用它,EnforceTimeout()
),这个方法需要可调用(API调用转换为可调用格式,返回response
,或exception
),并以毫秒为单位超时。
public static Object EnforceTimeout(Callable callable,Long TimeoutInMS) throws exceptions {
// Do Some Steps on current thread,but not create new thread/thread-pool
// 1. Start the clock
// 2. Make API call
// 3. Clock runs in background which takes care of the timeout,and if API call exceeds the time-limit then automatically enforce the exception.
}
现在,你们中的一些人可能会怀疑,我们如何在不创建新线程的情况下跟踪经过的时间。所以在这里,让我描述一个类似于事件循环(在 JavaScript 中)的策略。我们可以定义一个系统时钟。这个时钟应该能够处理 10 到 100 次这样的可调用超时。它可以检查优先队列上的此类可调用对象(以最接近结束时间的可调用对象为准),是否超过了时间限制。
您的下一个论点是,一个这样的系统时钟实例在管理大量可调用对象时效率低下。在这种情况下,我们需要 system-clock-manager,它将管理我们需要多少这样的时钟,它应该能够处理此类系统时钟实例的缩放。
请让我知道,如果在 Java 中有任何可能的话。如果我的问题/想法是重复的,请指导我进行讨论,在那里我可以找到有关相同问题的更多信息。非常感谢。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。