From: "nagachika (Tomoyuki Chikanaga)" Date: 2012-09-19T21:25:51+09:00 Subject: [ruby-dev:46144] [ruby-trunk - Bug #6441] IO.pipe on ENFILE Issue #6441 has been updated by nagachika (Tomoyuki Chikanaga). どうも IO.pipe で最後に開いた IO 2つは GC.start で手動で GC を実行しても回収されないみたいです。 $ ruby -ve 'GC.start;loop{IO.pipe.tap{|i|p i}.clear;GC.start}'" ruby 2.0.0dev (2012-08-08 trunk 36663) [x86_64-darwin10.8.0] [#, #] [#, #] [#, #] [#, #] [#, #] [#, #] ...(以下繰り返し) なので ulimit -n 9 だと動き続けることができるようでした。 はて、なんでしょう。 ---------------------------------------- Bug #6441: IO.pipe on ENFILE https://bugs.ruby-lang.org/issues/6441#change-29533 Author: naruse (Yui NARUSE) Status: Assigned Priority: Normal Assignee: authorNari (Narihiro Nakamura) Category: Target version: ruby -v: ruby 2.0.0dev (2012-05-16 trunk 35659) [x86_64-netbsd6.99.5] 今の Ruby は open(2) などで、errno=ENFILE が発生した場合、 すなわち fd を使いきっている場合には、rb_gc() を呼び、IO オブジェクトを GC して、 fd が解放されないか試み、それでもダメだったら諦めるとしています。 しかし、IO.pipe の場合はこれに失敗することがあります。 これは、lazy sweep が上記の目的のため T_FILE の場合は直ちに sweep することにしている所、 pipe の場合はその例外にあたらないからです。 -- http://bugs.ruby-lang.org/