instance method wait_poll

Ruby on Rails 6.1.7.10

Since v4.0.13 Private

Available in: v4.0.13 v4.1.16 v4.2.9 v5.2.8.1 v6.0.6 v6.1.7.10 v7.0.10 v7.1.6 v7.2.3 v8.0.4 v8.1.2

Signature

wait_poll(timeout)

Waits on the queue up to timeout seconds, then removes and returns the head of the queue.

Parameters

timeout req
Source
# File activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb, line 194
          def wait_poll(timeout)
            @num_waiting += 1

            t0 = Concurrent.monotonic_time
            elapsed = 0
            loop do
              ActiveSupport::Dependencies.interlock.permit_concurrent_loads do
                @cond.wait(timeout - elapsed)
              end

              return remove if any?

              elapsed = Concurrent.monotonic_time - t0
              if elapsed >= timeout
                msg = "could not obtain a connection from the pool within %0.3f seconds (waited %0.3f seconds); all pooled connections were in use" %
                  [timeout, elapsed]
                raise ConnectionTimeoutError, msg
              end
            end
          ensure
            @num_waiting -= 1
          end

Defined in activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb line 194 · View on GitHub · Improve this page · Find usages on GitHub

Defined in ActiveRecord::ConnectionAdapters::ConnectionPool::Queue

Type at least 2 characters to search.

↑↓ navigate · open · esc close