概述
eureka中有多个同一个服务的多个实例,其他服务在调用这个服务的时候如何去选择哪个服务进行调用,这就需要消费端进行判断实现负载均衡,eureka集成了ribbon主要目的就是实现服务调用的负载均衡。在消费端添加注解开启ribbon,消费端在调用其他服务的时候ribbon会从eureka中拉去相同服务名称的服务,使用负载均衡算法和动态代理方式去告诉消费端调用哪个服务,动态代理访问服务的远程调用是使用ip+端口的方式,因此消费端在进行服务调用的时候需要用服务的id而不是ip+端口,使用地址去访问的工作是ribbon实现的。
案例——template调用远程服务
template:spring自带的RPC远程调用工具
1.启动多个服务端
2.在消费端template生产方法中添加@LoadBalanced注解,加上这个注解意思就是开启ribbon,通过ribbon去实现负载均衡。
3.使用服务名称+接口路径调用服务
@RestController
@RequestMapping("/consumer")
public class ConsumerController {
@Autowired
RestTemplate restTemplate;
@Autowired
DiscoveryClient discoveryClient;
@GetMapping("/{id}")
public String getUser(@PathVariable Integer id){
//springcloud-server为服务端名称 testserver为接口路径
String url = "http://springcloud-server/testserver/" + id;
return restTemplate.getForObject(url, String.class);
}
}