X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b421d5c4754315cdd8b70b6bbea5b5f23fb425de..cdd8dc7bc4cca452e25c5b014e5f2bb592fb31ce:/services/api/app/middlewares/rack_socket.rb diff --git a/services/api/app/middlewares/rack_socket.rb b/services/api/app/middlewares/rack_socket.rb index 892dbf5278..08d163e6e2 100644 --- a/services/api/app/middlewares/rack_socket.rb +++ b/services/api/app/middlewares/rack_socket.rb @@ -19,12 +19,13 @@ class RackSocket # +app+ The next layer of the Rack stack. # # Accepts options: - # +:handler+ (Required) A class to handle new connections. Initialize will + # +:handler+ (Required) A class to handle new connections. #initialize will # call handler.new to create the actual handler instance object. When a new # websocket connection is established, #on_connect on the handler instance - # object to notify it about the connection. + # object will be called with the new connection. # - # +:mount+ The path for websocket connect requests, defaults to '/websocket'. + # +:mount+ The HTTP request path that will be recognized for websocket + # connect requests, defaults to '/websocket'. # # +:websocket_only+ If true, the server will only handle websocket requests, # and all other requests will result in an error. If false, unhandled @@ -43,18 +44,26 @@ class RackSocket if forked && EM.reactor_running? EM.stop end - Thread.new { - EM.run - } + Thread.new do + begin + EM.run + ensure + ActiveRecord::Base.connection.close + end + end die_gracefully_on_signal end else # faciliates debugging Thread.abort_on_exception = true # just spawn a thread and start it up - Thread.new { - EM.run - } + Thread.new do + begin + EM.run + ensure + ActiveRecord::Base.connection.close + end + end end # Create actual handler instance object from handler class. @@ -68,7 +77,11 @@ class RackSocket def call env request = Rack::Request.new(env) if request.path_info == @endpoint and Faye::WebSocket.websocket?(env) - ws = Faye::WebSocket.new(env) + if @handler.overloaded? + return [503, {"Content-Type" => "text/plain"}, ["Too many connections, try again later."]] + end + + ws = Faye::WebSocket.new(env, nil, :ping => 30) # Notify handler about new connection @handler.on_connect ws