class Falcon::Command::Serve
def run(verbose = false)
def run(verbose = false) app, _ = load_app(verbose) endpoint = Endpoint.parse(@options[:bind], **endpoint_options) bound_endpoint = Async::Reactor.run do Async::IO::SharedEndpoint.bound(endpoint) end.wait Async.logger.info(endpoint) do "Falcon taking flight! Using #{container_class} with concurrency: #{@options[:concurrency]}" end debug_trap = Async::IO::Trap.new(:USR1) debug_trap.ignore! if container_class.multiprocess? Async.logger.info "Full status: kill -USR1 #{-Process.pid}" end container_class.new(concurrency: @options[:concurrency], name: "Falcon Server") do |task, instance| task.async do if debug_trap.install! Async.logger.info "Per-process status: kill -USR1 #{Process.pid}" end debug_trap.trap do Async.logger.info(self) do |buffer| task.reactor.print_hierarchy(buffer) end end end server = Falcon::Server.new(app, bound_endpoint, endpoint.protocol, endpoint.scheme) server.run task.children.each(&:wait) end end