Class: Minke::Docker::ServiceDiscovery
- Inherits:
-
Object
- Object
- Minke::Docker::ServiceDiscovery
- Defined in:
- lib/minke/docker/service_discovery.rb
Overview
ServiceDiscovery allows you to look up the publicly accessible address and port for a server
Instance Method Summary collapse
-
#bridge_address_for(service_name, private_port) ⇒ Object
Will attempt to locate the private details for a running container given its name and private port Parameters: - service_name: the name of the running service - private_port: the private port which you wish to retrieve an address for Returns: private address for the container e.g.
-
#build_address(url) ⇒ Object
builds an address for the given url.
-
#initialize(project_name, docker_runner, docker_network = nil) ⇒ ServiceDiscovery
constructor
A new instance of ServiceDiscovery.
-
#public_address_for(service_name, private_port) ⇒ Object
Will attempt to locate the public details for a running container given its name and private port Parameters: - service_name: the name of the running service - private_port: the private port which you wish to retrieve an address for Returns: public address for the container e.g.
Constructor Details
#initialize(project_name, docker_runner, docker_network = nil) ⇒ ServiceDiscovery
Returns a new instance of ServiceDiscovery.
6 7 8 9 10 |
# File 'lib/minke/docker/service_discovery.rb', line 6 def initialize project_name, docker_runner, docker_network = nil @project_name = project_name @docker_runner = docker_runner @docker_network = docker_network end |
Instance Method Details
#bridge_address_for(service_name, private_port) ⇒ Object
Will attempt to locate the private details for a running container given its name and private port Parameters:
-
service_name: the name of the running service
-
private_port: the private port which you wish to retrieve an address for
Returns: private address for the container e.g. 172.17.0.2:8080
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
# File 'lib/minke/docker/service_discovery.rb', line 52 def bridge_address_for service_name, private_port ip = "" 10.times do begin container_details = find_container_by_name "/#{@project_name}_#{service_name}_1" ip = container_details .first .info['NetworkSettings']['Networks']["#{@docker_network}"]['IPAddress'] break rescue sleep(1) end end if ip.length < 1 raise "Unable to find bridge address for network: #{@docker_network}, container: #{service_name}, port: #{private_port}" end return "#{ip}:#{private_port}" end |
#build_address(url) ⇒ Object
builds an address for the given url
76 77 78 79 80 81 82 83 84 85 86 |
# File 'lib/minke/docker/service_discovery.rb', line 76 def build_address url if url.type == 'external' "#{url.protocol}://#{url.address}:#{url.port}#{url.path}" elsif url.type == 'bridge' address = bridge_address_for url.address, url.port "#{url.protocol}://#{address}#{url.path}" elsif url.type == 'public' address = public_address_for url.address, url.port "#{url.protocol}://#{address}#{url.path}" end end |
#public_address_for(service_name, private_port) ⇒ Object
Will attempt to locate the public details for a running container given its name and private port Parameters:
-
service_name: the name of the running service
-
private_port: the private port which you wish to retrieve an address for
Returns: public address for the container e.g. 0.0.0.0:8080
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
# File 'lib/minke/docker/service_discovery.rb', line 20 def public_address_for service_name, private_port ip = "" ports = nil 10.times do begin ip = @docker_runner.get_docker_ip_address container_details = find_container_by_name "/#{@project_name}_#{service_name}_1" #puts container_details ports = container_details.first.info['Ports'].select { |p| p['PrivatePort'] == private_port.to_i }.first rescue Exception sleep(1) end end if ports == nil || ports['PublicPort'] == nil raise "Unable to find public address for '#{service_name}' on port #{private_port}" end return "#{ip}:#{ports['PublicPort']}" end |