springcloud教程——Ribbon实现负载均衡

概述

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);
}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值