All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.dyno.contrib.EurekaHostsSupplier Maven / Gradle / Ivy

package com.netflix.dyno.contrib;

import java.util.ArrayList;
import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.google.common.base.Function;
import com.google.common.base.Supplier;
import com.google.common.collect.Collections2;
import com.google.common.collect.Lists;
import com.netflix.appinfo.AmazonInfo;
import com.netflix.appinfo.AmazonInfo.MetaDataKey;
import com.netflix.appinfo.InstanceInfo;
import com.netflix.appinfo.InstanceInfo.InstanceStatus;
import com.netflix.discovery.DiscoveryClient;
import com.netflix.discovery.DiscoveryManager;
import com.netflix.discovery.shared.Application;
import com.netflix.dyno.connectionpool.Host;
import com.netflix.dyno.connectionpool.HostSupplier;

/**
 * Simple class that implements {@link Supplier}<{@link List}<{@link Host}>>. It provides a List<{@link Host}>
 * using the {@link DiscoveryManager} which is the eureka client. 
 * 
 * Note that the class needs the eureka application name to discover all instances for that application. 
 * 
 * @author poberai
 */
public class EurekaHostsSupplier implements HostSupplier {

	private static final Logger Logger = LoggerFactory.getLogger(EurekaHostsSupplier.class);

	// The C* cluster name for discovering nodes
	private final String applicationName;
	private final DiscoveryClient discoveryClient;
	
	public EurekaHostsSupplier(String applicationName, DiscoveryClient dClient) {
		this.applicationName = applicationName.toUpperCase();
		this.discoveryClient = dClient;
	}

	@Override
	public List getHosts() {
		return getUpdateFromEureka();
	}
	
	private List getUpdateFromEureka() {
		
		if (discoveryClient == null) {
			Logger.error("Discovery client cannot be null");
			throw new RuntimeException("EurekaHostsSupplier needs a non-null DiscoveryClient");
		}

		Logger.info("Dyno fetching instance list for app: " + applicationName);
		
		Application app = discoveryClient.getApplication(applicationName);
		List hosts = new ArrayList();

		if (app == null) {
			return hosts;
		}

		List ins = app.getInstances();

		if (ins == null || ins.isEmpty()) {
			return hosts;
		}

		hosts = Lists.newArrayList(Collections2.transform(ins,
				
				new Function() {
					@Override
					public Host apply(InstanceInfo info) {
						
						Host.Status status = info.getStatus() == InstanceStatus.UP ? Host.Status.Up : Host.Status.Down;
						Host host = new Host(info.getHostName(), status);

						try {
							if (info.getDataCenterInfo() instanceof AmazonInfo) {
								AmazonInfo amazonInfo = (AmazonInfo)info.getDataCenterInfo();
								host.setRack(amazonInfo.get(MetaDataKey.availabilityZone));
							}
						}
						catch (Throwable t) {
							Logger.error("Error getting rack for host " + host.getHostName(), t);
						}

						return host;
					}
				}));
		
		Logger.info("Dyno found hosts from eureka - num hosts: " + hosts.size());
		
		return hosts;
	}

	@Override
	public String toString() {
		return EurekaHostsSupplier.class.getName();
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy