diff options
author | Jon Moss <me@jonathanmoss.me> | 2016-02-16 12:20:03 -0500 |
---|---|---|
committer | Jon Moss <me@jonathanmoss.me> | 2016-02-18 16:26:17 -0500 |
commit | cefcc0f66e185b808fc93040b1d7805f95bf929f (patch) | |
tree | 3ad1cc881186995317d3c64d86b56c669aa9e588 /actioncable/lib/action_cable/connection | |
parent | 9671df3ff797347940da2e813d005a4584ef464e (diff) | |
download | rails-cefcc0f66e185b808fc93040b1d7805f95bf929f.tar.gz rails-cefcc0f66e185b808fc93040b1d7805f95bf929f.tar.bz2 rails-cefcc0f66e185b808fc93040b1d7805f95bf929f.zip |
Fix `unsubscribed` server side behavior
Before this commit, the `unsubscribed` callbacks in Action Cable server
side channels were never called. This is because when a WebSocket
"goodbye" message was sent from the client, the Action Cable server
didn't properly clean up after the now closed WebSocket. This means that
memory could possibly skyrocket with this behavior, since part of this
commit is to properly remove closed subscriptions from the global
subscriptions hash. Say you have 10,000 users currently connected, and
then all 10,000 disconnect -- before this patch, Action Cable would
still hold onto information (and Ruby objects!) for all of these now
dead connections.
Diffstat (limited to 'actioncable/lib/action_cable/connection')
-rw-r--r-- | actioncable/lib/action_cable/connection/client_socket.rb | 7 | ||||
-rw-r--r-- | actioncable/lib/action_cable/connection/subscriptions.rb | 2 |
2 files changed, 3 insertions, 6 deletions
diff --git a/actioncable/lib/action_cable/connection/client_socket.rb b/actioncable/lib/action_cable/connection/client_socket.rb index ef937d7c16..95e1ac4c16 100644 --- a/actioncable/lib/action_cable/connection/client_socket.rb +++ b/actioncable/lib/action_cable/connection/client_socket.rb @@ -132,11 +132,8 @@ module ActionCable @ready_state = CLOSING @close_params = [reason, code] - if @stream - @stream.shutdown - else - finalize_close - end + @stream.shutdown if @stream + finalize_close end def finalize_close diff --git a/actioncable/lib/action_cable/connection/subscriptions.rb b/actioncable/lib/action_cable/connection/subscriptions.rb index d7f95e6a62..24934e12f2 100644 --- a/actioncable/lib/action_cable/connection/subscriptions.rb +++ b/actioncable/lib/action_cable/connection/subscriptions.rb @@ -54,7 +54,7 @@ module ActionCable end def unsubscribe_from_all - subscriptions.each { |id, channel| channel.unsubscribe_from_channel } + subscriptions.each { |id, channel| remove_subscription(channel) } end protected |