Class: HTTPX::Pool
Instance Method Summary collapse
- #close(connections = @connections) ⇒ Object
- #empty? ⇒ Boolean
-
#find_connection(uri, options) ⇒ Object
opens a connection to the IP reachable through
uri. - #init_connection(connection, _options) ⇒ Object
-
#initialize ⇒ Pool
constructor
A new instance of Pool.
- #next_tick ⇒ Object
Constructor Details
#initialize ⇒ Pool
Returns a new instance of Pool.
15 16 17 18 19 20 21 22 |
# File 'lib/httpx/pool.rb', line 15 def initialize @resolvers = {} @_resolver_ios = {} @timers = Timers::Group.new @selector = Selector.new @connections = [] @connected_connections = 0 end |
Instance Method Details
#close(connections = @connections) ⇒ Object
49 50 51 52 53 54 55 56 57 |
# File 'lib/httpx/pool.rb', line 49 def close(connections = @connections) @timers.cancel connections = connections.reject(&:inflight?) connections.each(&:close) next_tick until connections.none? { |c| @connections.include?(c) } @resolvers.each_value do |resolver| resolver.close unless resolver.closed? end if @connections.empty? end |
#empty? ⇒ Boolean
24 25 26 |
# File 'lib/httpx/pool.rb', line 24 def empty? @connections.empty? end |
#find_connection(uri, options) ⇒ Object
opens a connection to the IP reachable through uri. Many hostnames are reachable through the same IP, so we try to maximize pipelining by opening as few connections as possible.
76 77 78 79 80 |
# File 'lib/httpx/pool.rb', line 76 def find_connection(uri, ) @connections.find do |connection| connection.match?(uri, ) end end |
#init_connection(connection, _options) ⇒ Object
59 60 61 62 63 64 65 66 67 68 69 70 |
# File 'lib/httpx/pool.rb', line 59 def init_connection(connection, ) resolve_connection(connection) connection.timers = @timers connection.on(:open) do @connected_connections += 1 end connection.on(:unreachable) do resolver = find_resolver_for(connection) resolver.uncache(connection) if resolver resolve_connection(connection) end end |
#next_tick ⇒ Object
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/httpx/pool.rb', line 28 def next_tick catch(:jump_tick) do timeout = [next_timeout, @timers.wait_interval].compact.min if timeout && timeout.negative? @timers.fire throw(:jump_tick) end @selector.select(timeout, &:call) @timers.fire end rescue Interrupt @connections.each(&:reset) raise rescue StandardError => e @connections.each do |connection| connection.emit(:error, e) end end |