2007-04-09
■[ruby]net/httpの例外捕捉方法(2)
先日のNet::HTTPの例外補足方法、
rescue Timeout::Error
だけではエラーを捕捉しきれませんでした。*1
たしかErrnoの何かかEOFErrorだったはずなのですが、うっかりエラーメッセージを記録しわすれてしまったうえに、サーバの調子が悪い時にしかお目にかからないのでなかなか再現できません。
あれこれぐぐってみると、EOFErrorもErrnoも起きるような雰囲気。rescue Timeout::Error を指定するときには rescue もしくは rescue Exception の併用が欠かせませんね。
begin Net::HTTP.get(url) rescue puts "exception on HTTP: StandardError #{$!}" rescue Timeout::Error puts "exception on HTTP: TimeoutError" rescue Exception puts "exception on HTTP: #{$!}" end
2007/04/10追記
StandardError系とTimeout:Error以外の例外は通常のnet/httpでは出ないのかもしれません。もしそうならExceptionは「予期せぬ例外」になるので、もっと上位の部分(いわゆるmain関数やそれに近い所*2)で捕捉したほうが適切になりそうです。
後日もう少し調べてみます。
*1:当たり前といえば当たり前なのですが…。
*2:例えばHikiのhiki.cgiのエラートラップのように
トラックバック - http://d.hatena.ne.jp/cesar/20070409/p1
リンク元
- 46 http://june29.jp/2007/12/02/ruby-mechanize-rescue-exception/
- 24 http://www.google.co.jp/search?hl=ja&client=firefox-a&rls=org.mozilla:ja:official&hs=xxU&q=RSS+&+エスケープ&btnG=検索&lr=lang_ja
- 20 http://www.google.co.jp/search?sourceid=navclient&hl=ja&ie=UTF-8&rls=GFRD,GFRD:2007-15,GFRD:ja&q=RSS+エスケープ
- 12 http://d.hatena.ne.jp/keyworddiary/ruby
- 12 http://d.hatena.ne.jp/makura_a/20090920
- 11 http://www.google.com/search?hl=ja&lr=lang_ja&ie=UTF-8&oe=UTF-8&q=DBD::SQLite&num=50
- 10 http://d.hatena.ne.jp/afternoontea/20070603
- 10 http://d.hatena.ne.jp/kenmituo/20081028
- 10 http://www.google.co.jp/search?hl=ja&safe=off&client=firefox-a&hs=LIj&rls=org.mozilla:ja-JP-mac:official&q=nethttp+例外&aq=f&aqi=&aql=&oq=
- 8 http://d.hatena.ne.jp/kenmituo/20081028/1225181728