Class: ActiveRecord::ConnectionAdapters::ConnectionPool

Inherits:
Object
  • Object
show all
Defined in:
lib/active_record/fiber_patches.rb

Overview

ActiveRecord’s connection pool is based on threads. Since we are working with EM and a single thread, multiple fiber design, we need to provide our own connection pool that keys off of Fiber.current so that different fibers running in the same thread don’t try to use the same connection.

Instance Method Summary collapse

Constructor Details

#initialize(spec) ⇒ ConnectionPool

Returns a new instance of ConnectionPool.



52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# File 'lib/active_record/fiber_patches.rb', line 52

def initialize(spec)
  @spec = spec

  # The cache of reserved connections mapped to threads
  @reserved_connections = {}

  # The mutex used to synchronize pool access
  @connection_mutex = FiberedMonitor.new
  @queue = @connection_mutex.new_cond

  # default 5 second timeout unless on ruby 1.9
  @timeout = spec.config[:wait_timeout] || 5

  # default max pool size to 5
  @size = (spec.config[:pool] && spec.config[:pool].to_i) || 5

  @connections = []
  @checked_out = []
end

Instance Method Details

#clear_stale_cached_connections!Object



72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# File 'lib/active_record/fiber_patches.rb', line 72

def clear_stale_cached_connections!
  cache = @reserved_connections
  keys = Set.new(cache.keys)

  ActiveRecord::ConnectionAdapters.fiber_pools.each do |pool|
    pool.busy_fibers.each_pair do |object_id, fiber|
      keys.delete(object_id)
    end
  end

  keys.each do |key|
    next unless cache.has_key?(key)
    checkin cache[key]
    cache.delete(key)
  end
end