[#37730] [Ruby 1.9 - Bug #4962][Open] come back gem_prelude! — Yusuke Endoh <mame@...>

24 messages 2011/07/02

[#37840] [Ruby 1.9 - Feature #4985][Open] Add %S[] support for making a list of symbols — Aaron Patterson <aaron@...>

23 messages 2011/07/07

[#37866] [Backport87 - Feature #4996][Open] About 1.8.7 EOL — Shyouhei Urabe <shyouhei@...>

22 messages 2011/07/08

[#37913] [Ruby 1.9 - Bug #5003][Open] Enumerator#next segfaults in OS X Lion (10.7) — Ganesh Gunasegaran <ganesh.gunas@...>

16 messages 2011/07/09

[#37917] [Ruby 1.9 - Feature #5005][Open] Provide convenient access to original methods — Lazaridis Ilias <ilias@...>

13 messages 2011/07/09

[#37932] [Ruby 1.9 - Feature #5008][Open] Equal rights for Hash (like Array, String, Integer, Float) — Suraj Kurapati <sunaku@...>

31 messages 2011/07/09

[#37936] [Ruby 1.9 - Feature #5010][Open] Add Slop(-like) in stdlib and deprecate current OptionParser API — Rodrigo Rosenfeld Rosas <rr.rosas@...>

29 messages 2011/07/09

[#37968] [Ruby 1.9 - Bug #5015][Open] method_added" is called in addition to "method_undefined — Lazaridis Ilias <ilias@...>

14 messages 2011/07/10

[#38096] [Ruby 1.9 - Feature #5033][Open] PATCH: 1.9: gc_mark_children: Avoid gc_mark() tail recursion, use goto again. — Kurt Stephens <ks.ruby@...>

14 messages 2011/07/16

[#38109] [Ruby 1.9 - Bug #5034][Open] C Source Code formatting — Lazaridis Ilias <ilias@...>

18 messages 2011/07/16

[#38171] [Ruby 1.9 - Bug #5047][Open] Segfault (most likely involving require) — Jack Christensen <jack@...>

21 messages 2011/07/18

[#38182] [Ruby 1.9 - Feature #5054][Open] Compress a sequence of ends — ANDO Yasushi ANDO <andyjpn@...>

68 messages 2011/07/19

[#38197] [Ruby 1.9 - Feature #5056][Open] About 1.9 EOL — Shyouhei Urabe <shyouhei@...>

39 messages 2011/07/19
[#38900] [Ruby 1.9 - Feature #5056] About 1.9 EOL — Shota Fukumori <sorah@...> 2011/08/10

[#38902] Re: [Ruby 1.9 - Feature #5056] About 1.9 EOL — Yukihiro Matsumoto <matz@...> 2011/08/10

Hi,

[#39048] Re: [Ruby 1.9 - Feature #5056] About 1.9 EOL — SASADA Koichi <ko1@...> 2011/08/22

Hi,

[#39055] Re: [Ruby 1.9 - Feature #5056] About 1.9 EOL — Lucas Nussbaum <lucas@...> 2011/08/23

On 23/08/11 at 06:50 +0900, SASADA Koichi wrote:

[#38295] [Ruby 1.9 - Feature #5064][Open] HTTP user-agent class — Eric Hodel <drbrain@...7.net>

15 messages 2011/07/21

[#38391] [Ruby 1.9 - Bug #5076][Open] Mac OS X Lion Support — Yui NARUSE <naruse@...>

17 messages 2011/07/22

[#38503] [Ruby 1.9 - Feature #5096][Open] offer Logger-compatibility for ext — Eric Wong <normalperson@...>

16 messages 2011/07/25

[#38510] [Ruby 1.9 - Feature #5097][Assigned] Supported platforms of Ruby 1.9.3 — Yui NARUSE <naruse@...>

42 messages 2011/07/26

[#38526] [Backport92 - Backport #5099][Open] Backport r31875 load path performance problem — Aaron Patterson <aaron@...>

19 messages 2011/07/26

[#38538] [Ruby 1.9 - Feature #5101][Open] allow optional timeout for TCPSocket.new — Eric Wong <normalperson@...>

15 messages 2011/07/27

[#38610] [Ruby 1.9 - Feature #5120][Open] String#split needs to be logical — Alexey Muranov <muranov@...>

18 messages 2011/07/30

[#38623] [Ruby 1.9 - Feature #5123][Open] Alias Hash 1.9 as OrderedHash — Alexey Muranov <muranov@...>

14 messages 2011/07/31

[ruby-core:37727] Issue of Passenger and ruby-trunk

From: SASADA Koichi <ko1@...>
Date: 2011-07-02 01:17:57 UTC
List: ruby-core #37727
Hi,

We received a bug report ([ruby-dev:44011] [Ruby 1.9 - Bug #4958], in
Japanese) that says Passenger (*1) doesn't work with current trunk.  I
surveyed it and found out the reason.

*1: http://www.modrails.com/

In short, Passenger close most of file descriptors (fd) by
NativeSupport.close_all_file_descriptors().  However, current Ruby uses
2 fds for to communicate between [signal handler] <-> [timer thread] <->
[ruby thread].  I can run Passenger on commented out
"NativeSupport.close_all_file_descriptors" line.


Details:

(1) Ruby-side:

To avoid timer thread frequent invocation, we modified them totally.
And we decided to use pipe to communicate between [signal handler] <->
[timer thread] <-> [ruby thread].  We named this pipe "communication
pipe".  Ruby opens pipe at first.  Ruby also open pipe after fork().

(2) Passenger-side:

I assume that Passenger fork ruby process if request reached.  At first,
forked process close all file descriptors to avoid file descriptor leak.
 The method NativeSupport.close_all_file_descriptors(left_fds) forcibly
closes all file descriptors except left_fds.

quoted from 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) Problem

NativeSupport.close_all_file_descriptors(file_descriptors_to_leave_open)
closes communication pipe.  It causes critical problem to run ruby.

For exmaple, in report [ruby-dev:44011] [Ruby 1.9 - Bug #4958], the
following [BUG] was reported.

> /var/log/httpd/error_log:
> -------
> [ASYNC BUG] thread_timer: select
> EBADF
> 
> ruby 1.9.3dev (2011-07-01 trunk 32348) [x86_64-linux]
> 
> [NOTE]
> You may have encountered a bug in the Ruby interpreter or extension libraries.
> Bug reports are welcome.
> For details: http://www.ruby-lang.org/bugreport.html
> -----

I confirmed that I commented out the line
NativeSupport.close_all_file_descriptors, then Passenger run normally.


(4) Solution

How to solve it?  May I provide some C API or Ruby API to get pipe fds?

-- 
// SASADA Koichi at atdot dot net

In This Thread

Prev Next