[#62904] [ruby-trunk - Feature #9894] [Open] [RFC] README.EXT: document rb_gc_register_mark_object — normalperson@...
Issue #9894 has been reported by Eric Wong.
3 messages
2014/06/02
[#63321] [ANN] ElixirConf 2014 - Don't Miss Jos辿 Valim and Dave Thomas — Jim Freeze <jimfreeze@...>
Just a few more weeks until ElixirConf 2014!
6 messages
2014/06/24
[#63391] Access Modifiers (Internal Interfaces) — Daniel da Silva Ferreira <danieldasilvaferreira@...>
Hi,
3 messages
2014/06/28
[ruby-core:62890] [ruby-trunk - Bug #9688] Ruby's child process inherits parent's sockets (mswin)
From:
nagachika00@...
Date:
2014-06-01 17:21:34 UTC
List:
ruby-core #62890
Issue #9688 has been updated by Tomoyuki Chikanaga.
Backport changed from 2.0.0: DONE, 2.1: REQUIRED to 2.0.0: DONE, 2.1: DONE
Backported into `ruby_2_1` branch at r46305.
----------------------------------------
Bug #9688: Ruby's child process inherits parent's sockets (mswin)
https://bugs.ruby-lang.org/issues/9688#change-46999
* Author: Akio Tajima
* Status: Closed
* Priority: Normal
* Assignee: Usaku NAKAMURA
* Category: platform/windows
* Target version: current: 2.2.0
* ruby -v: ruby 2.1.1p76 (2014-02-24 revision 45161) [i386-mswin32_100]
* Backport: 2.0.0: DONE, 2.1: DONE
----------------------------------------
When Ruby application creates child process, sockets are inherited from the parent process.
This causes severe troubles.
In my situation, I have some web services using WEBrick and Sinatra. They invoke child process as a batch file using kernel.system method. And in the batch file I launch some long running applications by 'start'.
If these type of long running applications stay in running state, I never restart the services because the children grab server sockets while running. What is worse that Windows never report EADDRINUSE so I have no clue to judge its condition. Indeed 'netstat /b' reports the port is occupied by System not the child app.
Below is the reproduction script.
~~~
require 'socket'
require 'timeout'
exit unless RUBY_PLATFORM =~ /mswin/
BAT = "#{ENV['TMP']}#{File::SEPARATOR}test_inheritsock.bat"
File.open(BAT, 'w') do |fout|
fout.puts 'start ruby -e "sleep(10)"'
end
port = nil
TCPServer.open(0) do |gs|
port = gs.addr[1]
system(BAT)
end
File.delete BAT
gs = TCPServer.open(port)
running = true
client = false
begin
timeout(20) do
while running
Thread.start do
s = gs.accept
s.gets
s.close
running = false
end
unless client
client = true
Thread.start do
TCPSocket.open('localhost', port) do |sock|
sock.puts('')
end
end
else
sleep(1)
end
end
end
puts 'no problem'
rescue Timeout::Error
puts 'failed'
end
gs.close
~~~
The second opend TCPServer can not receive a connection request.
Unak already made no inheritance patch (https://gist.github.com/unak/9825743) and I tested it with Windowds7(x86) and Windows8.1(x64) and in both environments the above script runs completely.
So I wonder if the patch is applied to the trunk.
Thanks in advance.
--
https://bugs.ruby-lang.org/