Skip to content

Commit

Permalink
Fix support for Bundler restarts (#2576)
Browse files Browse the repository at this point in the history
By using `Process.setproctitle` instead of renaming `$0`.

See [original problem description](#2577 (comment)).
  • Loading branch information
CamJN authored Jan 6, 2025
1 parent 5d09279 commit 4315886
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 10 deletions.
1 change: 1 addition & 0 deletions CHANGELOG
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ Release 6.0.25 (Not yet released)
* Fixes compilation with clang 19 (latest Fedora update) by dropping a buggy stddev function from the moving average header. Closes GH-2580.
* [Standalone] Adds a config option to specify the stop timeout for Passenger: `--stop-timeout 120` or `PASSENGER_STOP_TIMEOUT=120`.
* [Standalone] Changes Passenger's (not apps') start timeout to 25s (from 15s), stop timeouts default to 60s.
* [Ruby] Fixes an issue where Bundler would try to re-exec the process name instead of the script. Closes GH-2567 and GH-2577.
*


Expand Down
9 changes: 7 additions & 2 deletions src/helper-scripts/meteor-loader.rb
Original file line number Diff line number Diff line change
Expand Up @@ -183,8 +183,13 @@ def self.load_app
end
exec("meteor run -p #{port} #{production} --settings settings.json")
end
$0 = options["process_title"] if options["process_title"]
$0 = "#{$0} (#{pid})"

if options["process_title"] && !options["process_title"].empty?
rename_process "#{options["process_title"]} (#{pid})"
else
rename_process "#{$0} (#{pid})"
end

return [pid, port]
end

Expand Down
12 changes: 10 additions & 2 deletions src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb
Original file line number Diff line number Diff line change
Expand Up @@ -304,9 +304,9 @@ def before_handling_requests(forked, options)
end

if options["process_title"] && !options["process_title"].empty?
$0 = options["process_title"] + ": " + options["app_group_name"]
rename_process "#{options["process_title"]}: #{options["app_group_name"]}"
else
$0 = "Passenger App: " + options["app_group_name"]
rename_process "Passenger App: #{options["app_group_name"]}"
end

# If we were forked from a preloader process then clear or
Expand Down Expand Up @@ -541,6 +541,14 @@ def dump_envvars
try_write_file("#{dir}/envvars", ENV.to_a.map { |k, v| "#{k} = #{v}" }.join("\n"))
end

def rename_process(name)
if Process.respond_to?(:setproctitle)
Process.setproctitle(name)
else
$0 = name
end
end

private
def running_bundler(options)
yield
Expand Down
18 changes: 12 additions & 6 deletions src/ruby_supportlib/phusion_passenger/preloader_shared_helpers.rb
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ module PreloaderSharedHelpers
def init(main_app)
options = LoaderSharedHelpers.init(main_app)

$0 = "#{SHORT_PROGRAM_NAME} AppPreloader: #{options['app_root']}"
LoaderSharedHelpers.rename_process pre_name(options)

if !Kernel.respond_to?(:fork)
message = "Smart spawning is not available on this Ruby " +
Expand All @@ -56,7 +56,7 @@ def init(main_app)
options
end

def accept_and_process_next_client(server_socket)
def accept_and_process_next_client(server_socket, options)
client = server_socket.accept
client.binmode
begin
Expand All @@ -75,7 +75,7 @@ def accept_and_process_next_client(server_socket)
end

if doc['command'] == 'spawn'
handle_spawn_command(client, doc)
handle_spawn_command(client, doc, options)
else
client.write(Utils::JSON.generate(
:result => 'error',
Expand All @@ -94,7 +94,7 @@ def accept_and_process_next_client(server_socket)
end
end

def handle_spawn_command(client, doc)
def handle_spawn_command(client, doc, options)
work_dir = doc['work_dir']
LoaderSharedHelpers.record_journey_step_end('PRELOADER_PREPARATION',
'STEP_PERFORMED', work_dir)
Expand All @@ -114,7 +114,7 @@ def handle_spawn_command(client, doc)

if pid.nil?
begin
$0 = "#{$0} (forking...)"
LoaderSharedHelpers.rename_process "#{pre_name(options)} (forking...)"
LoaderSharedHelpers.record_journey_step_end('PRELOADER_FORK_SUBPROCESS',
'STEP_PERFORMED', work_dir)
LoaderSharedHelpers.run_block_and_record_step_progress('PRELOADER_SEND_RESPONSE', work_dir) do
Expand Down Expand Up @@ -164,7 +164,7 @@ def run_main_loop(server, options)
# https://code.google.com/p/phusion-passenger/issues/detail?id=915
ios = Kernel.select([server_socket, STDIN])[0]
if ios.include?(server_socket)
result, subprocess_work_dir = accept_and_process_next_client(server_socket)
result, subprocess_work_dir = accept_and_process_next_client(server_socket, options)
if result == :forked
return subprocess_work_dir
end
Expand All @@ -188,6 +188,12 @@ def run_main_loop(server, options)
File.unlink(socket_filename) rescue nil
end
end

private
def pre_name(options)
"#{SHORT_PROGRAM_NAME} AppPreloader: #{options['app_root']}"
end

end

end # module PhusionPassenger

0 comments on commit 4315886

Please sign in to comment.