在Spring Cloud中发现其他所有服务

在Spring Cloud中发现其他所有服务

在使用Spring Cloud时会遇到一些需求,比如创建一个服务注册和发现的服务来处理一些服务的动态配置相关操作,这就需要用到DiscoveryClient 类来实现了:

package org.springframework.cloud.client.discovery;

import java.util.List;

import org.springframework.cloud.client.ServiceInstance;

/**
 * DiscoveryClient represents read operations commonly available to Discovery service such as
 * Netflix Eureka or consul.io
 * @author Spencer Gibb
 */
public interface DiscoveryClient {

    /**
     * A human readable description of the implementation, used in HealthIndicator
     * @return the description
     */
    String description();

    /**
     * @deprecated use the {@link org.springframework.cloud.client.serviceregistry.Registration} bean instead
     *
     * @return ServiceInstance with information used to register the local service
     */
    @Deprecated
    ServiceInstance getLocalServiceInstance();

    /**
     * Get all ServiceInstances associated with a particular serviceId
     * @param serviceId the serviceId to query
     * @return a List of ServiceInstance
     */
    List<ServiceInstance> getInstances(String serviceId);

    /**
     * @return all known service ids
     */
    List<String> getServices();

}

使用示例:

    @Autowired
    private DiscoveryClient discoveryClient;

    volatile private Map<String, MyRegistClient> clientMap;

    public void recovery(){
        List<String> services = discoveryClient.getServices();
        Map<String, MyRegistClient> clientMap = new HashMap<>();
        for (String service: services){
            if(service.startsWith("myClient")){
                clientMap.put(service, genClient(service));
            }
        }
        this.clientMap = clientMap;
    }
posted @ 2018-01-06 12:13  海角Q  阅读(137)  评论(0编辑  收藏  举报