Class: Wurk::Swarm::ChildBoot
- Inherits:
-
Object
- Object
- Wurk::Swarm::ChildBoot
- Includes:
- Component
- Defined in:
- lib/wurk/swarm/child_boot.rb
Overview
Step 5 of the boot ordering. Runs inside each forked child:
* reset signal traps inherited from the parent,
* reconnect ActiveRecord (if loaded) + open a fresh Redis pool,
* apply the slot's queues + concurrency to the default capsule,
* install child signal handlers (TERM/INT drain, TSTP quiet,
USR2 reopen logs),
* launch the Wurk::Launcher and block until shutdown.
Kept separate from Wurk::Swarm so the parent supervisor stays focused on PID supervision (SRP).
Constant Summary collapse
- CHILD_SIGNALS =
{ 'TERM' => :term, 'INT' => :term, 'TSTP' => :tstp, 'USR2' => :usr2 }.freeze
Constants included from Component
Component::DEFAULT_THREAD_PRIORITY, Component::PROCESS_NONCE
Instance Attribute Summary
Attributes included from Component
Instance Method Summary collapse
-
#initialize(config, slot, index) ⇒ ChildBoot
constructor
A new instance of ChildBoot.
- #run ⇒ Object
Methods included from Component
#default_tag, #fire_event, #handle_exception, #hostname, #identity, #leader?, #logger, #mono_ms, #process_nonce, #real_ms, #redis, #safe_thread, #tid, #watchdog
Constructor Details
#initialize(config, slot, index) ⇒ ChildBoot
Returns a new instance of ChildBoot.
24 25 26 27 28 29 |
# File 'lib/wurk/swarm/child_boot.rb', line 24 def initialize(config, slot, index) @config = config @slot = slot @index = index @signal_queue = ::Thread::Queue.new end |
Instance Method Details
#run ⇒ Object
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/wurk/swarm/child_boot.rb', line 31 def run reset_inherited_signals reconnect_after_fork Wurk.server = true # :fork runs in each child after our internal AR/Redis reconnect and # before fetching, so apps can reopen sockets / restart threads / # reconnect non-fork-safe libs (Ent §7.4). It never fires in the parent # (which only forks + supervises). Like :startup, the child's forked # copy of the bucket is cleared after dispatch, so siblings fire theirs. fire_event(:fork) apply_slot_to_config # :startup must fire in each worker child before its managers spin up # (Sidekiq contract, reraise: true). The parent supervisor never runs # jobs, so the non-swarm CLI path fires it once per process — for the # swarm, each child fires it here. Its own forked copy of the bucket is # cleared after, so siblings still fire their own. fire_event(:startup, reraise: true) run_launcher exit 0 rescue StandardError, ::Wurk::Shutdown => e @config.logger.error { "swarm child ##{@index} (#{::Process.pid}) crashed: #{e.class}: #{e.}" } exit 1 end |