{"version":"1.0","blog_title":"tmtms \u306e\u30e1\u30e2","title":"Ruby \u306e Timeout.timeout \u306b\u4f8b\u5916\u30af\u30e9\u30b9\u3092\u6307\u5b9a\u3059\u308b\u6642\u306e\u6ce8\u610f","categories":["Ruby"],"published":"2014-06-19 06:48:12","type":"rich","image_url":null,"height":"190","author_name":"tmtms","blog_url":"https://blog.tmtms.net/","provider_url":"https://hatena.blog","html":"<iframe src=\"https://hatenablog-parts.com/embed?url=https%3A%2F%2Fblog.tmtms.net%2Fentry%2F2014%2F06%2F19%2Fruby-timeout\" title=\"Ruby \u306e Timeout.timeout \u306b\u4f8b\u5916\u30af\u30e9\u30b9\u3092\u6307\u5b9a\u3059\u308b\u6642\u306e\u6ce8\u610f - tmtms \u306e\u30e1\u30e2\" class=\"embed-card embed-blogcard\" scrolling=\"no\" frameborder=\"0\" style=\"display: block; width: 100%; height: 190px; max-width: 500px; margin: 10px 0px;\"></iframe>","author_url":"https://blog.hatena.ne.jp/tmtms/","description":"\u3061\u3087\u3063\u3068\u30cf\u30de\u3063\u305f\u306e\u3067\u30e1\u30e2\u3002 Ruby \u306e Timeout \u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f7f\u3046\u3068\u3001\u4e00\u5b9a\u306e\u6642\u9593\u304c\u904e\u304e\u3066\u3082\u7d42\u308f\u3089\u306a\u3044\u51e6\u7406\u3092\u4e2d\u65ad\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002 require 'timeout' def hoge sleep end def main Timeout.timeout(3) do hoge end rescue Timeout::Error => e p 'main: timeout', e.backtrace.first end main \u3053\u306e\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u5b9f\u884c\u3059\u308b\u30683\u79d2\u305f\u3063\u3066\u304b\u3089\u7d42\u4e86\u3057\u307e\u3059\u3002 % ruby t1.rb \"main: timeout\" \"t1.rb:4:in `sleep'\" \u30d0\u30c3\u30af\u2026","width":"100%","url":"https://blog.tmtms.net/entry/2014/06/19/ruby-timeout","provider_name":"Hatena Blog"}