From 43158868379b9c3be649f90033bd567809e7c93a Mon Sep 17 00:00:00 2001 From: Camden Narzt <6243207+CamJN@users.noreply.github.com> Date: Mon, 6 Jan 2025 08:54:50 -0700 Subject: [PATCH] Fix support for Bundler restarts (#2576) By using `Process.setproctitle` instead of renaming `$0`. See [original problem description](https://github.com/phusion/passenger/issues/2577#issuecomment-2525105583). --- CHANGELOG | 1 + src/helper-scripts/meteor-loader.rb | 9 +++++++-- .../phusion_passenger/loader_shared_helpers.rb | 12 ++++++++++-- .../preloader_shared_helpers.rb | 18 ++++++++++++------ 4 files changed, 30 insertions(+), 10 deletions(-) diff --git a/CHANGELOG b/CHANGELOG index 6189a25e07..188ea5b76b 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -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. * diff --git a/src/helper-scripts/meteor-loader.rb b/src/helper-scripts/meteor-loader.rb index 9e4ad25ff1..94a07b4cdc 100755 --- a/src/helper-scripts/meteor-loader.rb +++ b/src/helper-scripts/meteor-loader.rb @@ -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 diff --git a/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb b/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb index 422a61bebc..325666e20d 100644 --- a/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb +++ b/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb @@ -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 @@ -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 diff --git a/src/ruby_supportlib/phusion_passenger/preloader_shared_helpers.rb b/src/ruby_supportlib/phusion_passenger/preloader_shared_helpers.rb index 26e7f50dda..3593b28ac2 100644 --- a/src/ruby_supportlib/phusion_passenger/preloader_shared_helpers.rb +++ b/src/ruby_supportlib/phusion_passenger/preloader_shared_helpers.rb @@ -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 " + @@ -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 @@ -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', @@ -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) @@ -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 @@ -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 @@ -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