Class: Async::HTTP::Pool

Inherits:
Object
  • Object
show all
Defined in:
lib/async/http/pool.rb

Overview

Pool behaviours

  • Single request per connection (HTTP/1 without keep-alive)

  • Multiple sequential requests per connection (HTTP1 with keep-alive)

  • Multiplex requests per connection (HTTP2)

In general we don’t know the policy until connection is established.

This pool doesn’t impose a maximum number of open resources, but it WILL block if there are no available resources and trying to allocate another one fails.

Resources must respond to #multiplex -> 1 or more. #reusable? -> can be used again.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(limit = nil, &block) ⇒ Pool

Returns a new instance of Pool.



41
42
43
44
45
46
47
48
49
# File 'lib/async/http/pool.rb', line 41

def initialize(limit = nil, &block)
	@resources = {} # resource => count
	@available = Async::Notification.new
	
	@limit = limit
	@active = 0
	
	@constructor = block
end

Instance Attribute Details

#activeObject (readonly)

The number of allocated resources.



52
53
54
# File 'lib/async/http/pool.rb', line 52

def active
  @active
end

#resourcesObject (readonly)

All allocated resources.



64
65
66
# File 'lib/async/http/pool.rb', line 64

def resources
  @resources
end

Instance Method Details

#acquireObject



70
71
72
73
74
75
76
77
78
79
80
# File 'lib/async/http/pool.rb', line 70

def acquire
	resource = wait_for_resource
	
	return resource unless block_given?
	
	begin
		yield resource
	ensure
		release(resource)
	end
end

#busy?Boolean

Whether there are resources which are currently in use.

Returns:

  • (Boolean)


55
56
57
58
59
60
61
# File 'lib/async/http/pool.rb', line 55

def busy?
	@resources.collect do |_,usage|
		return true if usage > 0
	end
	
	return false
end

#closeObject



92
93
94
95
96
97
# File 'lib/async/http/pool.rb', line 92

def close
	@resources.each_key(&:close)
	@resources.clear
	
	@active = 0
end

#empty?Boolean

Returns:

  • (Boolean)


66
67
68
# File 'lib/async/http/pool.rb', line 66

def empty?
	@resources.empty?
end

#release(resource) ⇒ Object

Make the resource resources and let waiting tasks know that there is something resources.



83
84
85
86
87
88
89
90
# File 'lib/async/http/pool.rb', line 83

def release(resource)
	# A resource that is not good should also not be reusable.
	if resource.reusable?
		reuse(resource)
	else
		retire(resource)
	end
end

#to_sObject



99
100
101
# File 'lib/async/http/pool.rb', line 99

def to_s
	"\#<#{self.class} resources=#{availability_string} limit=#{@limit.inspect}>"
end