[#44014] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある — Narihiro Nakamura <authornari@...>

nariです。

14 messages 2011/07/02
[#44019] Re: [ruby-core:37707] [Ruby 1.9 - Bug #3781] FIBER_USE_NATIVE が有効だと落ちるスクリプトがある — KOSAKI Motohiro <kosaki.motohiro@...> 2011/07/02

> 本当はgc_mark()の際に毎回stack_check()するのがいいと思うのですが、

[#44027] [RubyKaigi] Next version of Ruby 1.8 and 1.9 — "Yuki Sonoda (Yugui)" <yugui@...>

-----BEGIN PGP SIGNED MESSAGE-----

16 messages 2011/07/03

[#44156] [Ruby 1.9 - Feature #5053][Open] ruby コマンドと libruby の食い違いチェック — Makoto Kishimoto <redmine@...>

20 messages 2011/07/19

[#44185] [Ruby 1.9 - Bug #5074][Open] "[BUG] cfp consistency error - send" on TestEnumerator#test_feed_yielder (test/ruby/test_enumerator.rb) — Shota Fukumori <sorah@...>

10 messages 2011/07/22

[#44189] [Ruby 1.9 - Bug #5075][Assigned] invalid *fdp in Mac OS X and FreeBSD over recvmsg with SCM_RIGHTS — Yui NARUSE <naruse@...>

12 messages 2011/07/22

[#44210] 1.9.3 (以降) の BigDecimal について — Tadayoshi Funaba <tadf@...>

BigDecimal() で整数、浮動小数点数、有理数などを受けとれるようになって、

14 messages 2011/07/23
[#44275] Re: 1.9.3 (以降) の BigDecimal について — Tadayoshi Funaba <tadf@...> 2011/07/30

変換には明示的なものとそうでないものがありますが、

[#44223] [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Yui NARUSE <naruse@...>

21 messages 2011/07/25
[#44229] Re: [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — KOSAKI Motohiro <kosaki.motohiro@...> 2011/07/25

> == 成瀬の提案

[#44230] Re: [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Urabe Shyouhei <shyouhei@...> 2011/07/26

卜部です

[#44236] Re: [Ruby 1.9 - Bug #5094][Assigned] Supported platforms of Ruby 1.9.3 — Yusuke ENDOH <mame@...> 2011/07/26

遠藤です。

[#44254] [Ruby 1.8 - Bug #5105][Open] CGI::Session#session_id の生成方法について — Masahiro Tomita <tommy@...>

14 messages 2011/07/27
[#44256] [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — Yui NARUSE <naruse@...> 2011/07/27

[#44258] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — とみたまさひろ <tommy@...> 2011/07/27

とみたです。

[#44262] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — "NARUSE, Yui" <naruse@...> 2011/07/27

(2011/07/27 19:47), とみたまさひろ wrote:

[#44263] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — とみたまさひろ <tommy@...> 2011/07/27

とみたです。

[#44270] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — とみたまさひろ <tommy@...> 2011/07/29

とみたです。

[#44271] Re: [Ruby 1.8 - Bug #5105] CGI::Session#session_id の生成方法について — Tanaka Akira <akr@...> 2011/07/29

2011年7月29日20:04 とみたまさひろ <tommy@tmtm.org>:

[ruby-dev:44013] Re: [Ruby 1.9 - Bug #4958][Open] Internal server error (PhusionPassenger::Rack::ApplicationSpawner::Error)

From: SASADA Koichi <ko1@...>
Date: 2011-07-02 00:52:58 UTC
List: ruby-dev #44013
 ささだです.

(2011/07/01 14:29), Masahiro Iura wrote:
> 障害内容:
> PhusionPassenger 経由で Ruby on Rails のコンテンツを接続しているのですが、
> 数日前から Web ブラウザからアクセスすると「Internal server error 」が表示され、
> 所定のページが表示されない。
> ruby 1.9 はほぼ毎日更新しています。
> 
> アクセス後にログファイルを確認すると以下の内容が表示されます。
> 何度やっても同じメッセージが出ます。
> お手数ですがよろしくお願いします。

 はじめて Passenger なるものを触ってみました.他のソフトのソースを見た
のも久しぶりな気がします.

 調べてみて,理由がわかりました.結論から言うと,Passenger が酷いこと
(?)をしているので,このエラーが出た,というものです.

(1) Ruby 側の事情

 先日,タイマスレッドの構造を変更しまして,signal handler <-> timer
thread <-> Ruby thread の間の通信を pipe を用いることにしました.プロセ
ス起動時に pipe を開き,そいつでこれらの間を同期的に通信します.fork 後
も,同様に新しい pipe を開きます.

(2) Passenger の事情

 Passenger は,リクエストが来たら ruby を fork して,子プロセスで処理を
させます(多分).ただ,子プロセスが無駄に file descriptor を開いてし
まって,変なリークを起こさないために,fork で子プロセスが生成された後,
リクエスト処理を行う前の準備処理の時点で,stdin/out や,Passenger が親子
の通信で利用する fd 以外を,問答無用で close してくれます.無駄なfd 資源
がリークしなくなるのでやったね!

問題の箇所:
passenger-3.0.5/lib/phusion_passenger/abstract_server.rb より引用
> # During Passenger's early days, we used to close file descriptors based
> # on a white list of file descriptors. That proved to be way too fragile:
> # too many file descriptors are being left open even though they shouldn't
> # be. So now we close file descriptors based on a black list.
> #
> # Note that STDIN, STDOUT and STDERR may be temporarily set to
> # different file descriptors than 0, 1 and 2, e.g. in unit tests.
> # We don't want to close these either.
> file_descriptors_to_leave_open = [0, 1, 2,
> 	b.fileno, server_socket.fileno,
> 	fileno_of(STDIN), fileno_of(STDOUT), fileno_of(STDERR)
> ].compact.uniq
> NativeSupport.close_all_file_descriptors(file_descriptors_to_leave_open)

(3) 今回の原因

 というわけで,(1) でせっかく作った pipe を,(2) の処理として閉じられて
しまったので,今回の [BUG] に至ったわけです.

 この
NativeSupport.close_all_file_descriptors(file_descriptors_to_leave_open)
をコメントアウトすると,元気に動くことを確認しました.



 いやはや,なんというか.こういうのって普通?

 思わぬ互換性の問題にあたったんですが,さてどうするべきでしょうか.閉じ
て欲しくない fd を返すような API を,一つ作りますかねえ?

-- 
// SASADA Koichi at atdot dot net

In This Thread