首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ruby超时不超时

Ruby超时不超时
EN

Stack Overflow用户
提问于 2017-07-31 16:12:01
回答 1查看 594关注 0票数 0

我正在使用firebird数据库gem连接到用户指定的数据库。只要用户提供正确的数据,它就能正常工作。如果没有,gem将无法连接,并且在gem抛出异常之前需要很长时间。我尝试使用Timeout:timeout,如下所示:

代码语言:javascript
复制
database = Fb:Database(connection_data)
Timeout::timeout(5) do
  database.connect #that's the part that takes long to connect
end

但它不会超时。它只是简单地等待(这是一个很长的等待,超过一分钟),然后抛出gem异常(它不是超时异常)。看起来代码的执行时间不超过5秒(根据超时时间),只不过花了1-2分钟。我一直在寻找一个解释(也检查了源代码),但没有找到任何解释。我真的不想修复它(因为它无论如何都会被移到延迟的作业中),但我想知道为什么,以及如何忽略超时。

而且,下面的代码运行良好。

代码语言:javascript
复制
Timeout::timeout(5) do
  sleep(10)
end
EN

回答 1

Stack Overflow用户

发布于 2017-07-31 17:13:59

超时块在一个新线程中运行代码,当timeout在5秒后发生时,异常被强制抛出(我相信是Thread.raise)到运行database.connect的线程中。(Timeout module code)

这种中断可能发生在任何行上;在本例中,它可能是某种救援块(在此之后抛出一个自定义错误),也可能是没有正确处理它的任何地方,从而使它处于无效状态。一个库不太可能在任何地方都进行防御性编码。

您可以阅读有关在this Reddit thread中使用Timeout::timeout的问题的更多信息。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45410527

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档