class Protobuf::Rpc::EventedRunner
def self.run(server)
def self.run(server) # Ensure errors thrown within EM are caught and logged appropriately EventMachine.error_handler do |error| if error.message == 'no acceptor' raise 'Failed binding to %s:%d (%s)' % [server.host, server.port, error.message] else Protobuf::Logger.error error.message Protobuf::Logger.error error.backtrace.join("\n") end end # Startup and run the rpc server EM.schedule do EventMachine.start_server(server.host, server.port, Protobuf::Rpc::EventedServer) && \ Protobuf::Logger.info('RPC Server listening at %s:%d in %s' % [server.host, server.port, server.env]) end # Join or start the reactor EM.reactor_running? ? EM.reactor_thread.join : EM.run end
def self.stop
def self.stop EventMachine.stop_event_loop if EventMachine.reactor_running? Protobuf::Logger.info 'Shutdown complete' end