首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Ruby Net::OpenTimeout: execution expired

Ruby Net::OpenTimeout: execution expired
EN

Stack Overflow用户
提问于 2017-02-04 11:24:58
回答 3查看 21.8K关注 0票数 15

在我的机器上的几个主机上,我总是收到这个错误,例如:

代码语言:javascript
运行
复制
require 'open-uri'
open('https://google.com').read


Net::OpenTimeout: execution expired
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/net/http.rb:904:in `initialize'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/net/http.rb:904:in `open'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/net/http.rb:904:in `block in connect'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/timeout.rb:103:in `timeout'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/net/http.rb:902:in `connect'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/net/http.rb:887:in `do_start'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/net/http.rb:876:in `start'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:323:in `open_http'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:741:in `buffer_open'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:212:in `block in open_loop'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:210:in `catch'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:210:in `open_loop'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:151:in `open_uri'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:721:in `open'
    from /usr/local/opt/rbenv/versions/2.4.0/lib/ruby/2.4.0/open-uri.rb:35:in `open'
    from (irb):3
    from /usr/local/opt/rbenv/versions/2.4.0/bin/irb:11:in `<main>'

在其他情况下不会发生,例如

代码语言:javascript
运行
复制
open('https://twitter.com').read

来自rbenv和macOS 10.12.3的Ruby2.4.0。还测试了Ruby2.0.0- macOS上的系统版本。

当我curl或使用Node的request时,我没有得到任何错误和预期的结果。所以这不是被阻止的主机,我的IP也没有被阻止。

已尝试重新安装Ruby,重新启动计算机,但仍然出现问题。

有什么建议吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-02-05 01:10:27

看起来这是一个Ruby解析DNS的问题。

添加了require 'resolv-replace',现在它立即打开连接。

资料来源:https://stackoverflow.com/a/27485369/116925 https://github.com/ruby/ruby/pull/597#issuecomment-40507119

票数 30
EN

Stack Overflow用户

发布于 2020-06-18 14:43:00

我在docker容器中收到来自rails应用程序的错误,重新启动docker服务解决了这个问题:

代码语言:javascript
运行
复制
sudo service docker start
票数 1
EN

Stack Overflow用户

发布于 2019-12-03 06:55:46

我找到了这个问题的另一个原因。我有一个网络,其中宣布IPv6是可路由的,但不是。这会导致IPv6试图被使用,从而导致错误。

所以我不得不禁用IPv6。

对于Red Hat Enterprise Linux 7:

代码语言:javascript
运行
复制
# cat /etc/sysctl.d/10-ipv6.conf 
net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
# sysctl -p

require 'resolv-replace'也有帮助,但我猜它只是解析成了IPv4,所以我不想以这种方式限制应用程序。

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

https://stackoverflow.com/questions/42036133

复制
相关文章

相似问题

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