1、@EnableFeignClients
/**
*启动类中使用@EnableFeignClients注解,程序启动时会扫描当前包及其子包下所有的@FeignClient注解的接口
并给这些接口创建动态代理类对象.
调用代理类的方法的时候.利用反射的机制,可以拿到当前的对象所有的接口,可以获取到接口上的注解信息.
===> http://product-service/product/get?pid=1
最终使用RestTemplate对路径做解析,把服务名替换成具体的IP信息.
===> http://192.168.1.17:8081/product/get?pid=1
发起http请求,实现远程调用.根据接口的返回值,将返回结果解析返回值的类型。最终返回给调用者.
*/
@FeignClient(name = "product-service",fallback = ProductFeignFallBack.class)
public interface ProductFeignApi {
//http://product-service/product/get?pid=1
@RequestMapping("/product/get")
public Product findByPid(@RequestParam("pid") Long pid);
}
//使用@LoadBalanced修改RestTemplate
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
/**
* 修改负载均衡配置为随机访问
*/
@LoadBalancerClient(name = "product-service",configuration = RandomLoadbalancerConfig.class)
public class RandomLoadbalancerConfig {
@Bean
public ReactorLoadBalancer<ServiceInstance> reactorServiceInstanceLoadBalancer(Environment environment,
LoadBalancerClientFactory loadBalancerClientFactory) {
String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
return new RandomLoadBalancer(
loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
}
}