customize getting service instance in service subscribe.

pull/923/head
liuxx 5 years ago
parent aff20a84a7
commit 7dd7fa9c49

@ -16,8 +16,10 @@
package com.alibaba.cloud.dubbo.autoconfigure; package com.alibaba.cloud.dubbo.autoconfigure;
import java.util.Collection; import java.util.Collection;
import java.util.Optional;
import java.util.function.Supplier; import java.util.function.Supplier;
import com.alibaba.cloud.dubbo.metadata.repository.MetadataServiceInstanceSelector;
import org.apache.dubbo.config.ProtocolConfig; import org.apache.dubbo.config.ProtocolConfig;
import org.apache.dubbo.config.spring.ServiceBean; import org.apache.dubbo.config.spring.ServiceBean;
import org.apache.dubbo.config.spring.context.event.ServiceBeanExportedEvent; import org.apache.dubbo.config.spring.context.event.ServiceBeanExportedEvent;
@ -42,6 +44,7 @@ import com.alibaba.cloud.dubbo.service.IntrospectiveDubboMetadataService;
import com.alibaba.cloud.dubbo.util.JSONUtils; import com.alibaba.cloud.dubbo.util.JSONUtils;
import feign.Contract; import feign.Contract;
import org.springframework.util.CollectionUtils;
/** /**
* Spring Boot Auto-Configuration class for Dubbo Metadata * Spring Boot Auto-Configuration class for Dubbo Metadata
@ -68,6 +71,15 @@ public class DubboMetadataAutoConfiguration {
return new DubboServiceBeanMetadataResolver(contract); return new DubboServiceBeanMetadataResolver(contract);
} }
@Bean
@ConditionalOnMissingBean
public MetadataServiceInstanceSelector metadataServiceInstanceSelector() {
return serviceInstances ->
CollectionUtils.isEmpty(serviceInstances)
? Optional.empty()
: serviceInstances.stream().findAny();
}
@Bean @Bean
public Supplier<ProtocolConfig> dubboProtocolConfigSupplier( public Supplier<ProtocolConfig> dubboProtocolConfigSupplier(
ObjectProvider<Collection<ProtocolConfig>> protocols) { ObjectProvider<Collection<ProtocolConfig>> protocols) {

@ -165,6 +165,9 @@ public class DubboServiceMetadataRepository
@Autowired @Autowired
private DiscoveryClient discoveryClient; private DiscoveryClient discoveryClient;
@Autowired
private MetadataServiceInstanceSelector metadataServiceInstanceSelector;
@Autowired @Autowired
private JSONUtils jsonUtils; private JSONUtils jsonUtils;
@ -618,7 +621,7 @@ public class DubboServiceMetadataRepository
} }
protected void initSubscribedDubboMetadataService(String serviceName) { protected void initSubscribedDubboMetadataService(String serviceName) {
discoveryClient.getInstances(serviceName).stream().findAny() metadataServiceInstanceSelector.choose(discoveryClient.getInstances(serviceName))
.map(this::getDubboMetadataServiceURLs) .map(this::getDubboMetadataServiceURLs)
.ifPresent(dubboMetadataServiceURLs -> { .ifPresent(dubboMetadataServiceURLs -> {
dubboMetadataServiceURLs.forEach(dubboMetadataServiceURL -> { dubboMetadataServiceURLs.forEach(dubboMetadataServiceURL -> {

@ -0,0 +1,23 @@
package com.alibaba.cloud.dubbo.metadata.repository;
import org.springframework.cloud.client.ServiceInstance;
import java.util.List;
import java.util.Optional;
/**
* metadata service instance selector
*
* @author liuxx
* @date 2019/9/4
*/
public interface MetadataServiceInstanceSelector {
/**
* choose a service instance to get metadata
* @param serviceInstances all service instance
* @return the service instance to get metadata
*/
Optional<ServiceInstance> choose(List<ServiceInstance> serviceInstances);
}
Loading…
Cancel
Save