第四章 AlibabaCloud集成Ribbon实现负载均衡

本文介绍了负载均衡的概念及其在分布式系统中的应用,并探讨了基于Alibaba Cloud使用Ribbon实现客户端负载均衡的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.什么负载均衡和常见的解决方案

  • 什么是负载均衡(Load Balance)
    分布式系统中一个非常重要的概念,当访问的服务具有多个实例时,需要根据某种“均衡”的策略决定请求发往哪个节点,这就是所谓的负载均衡,原理是将数据流量分摊到多个服务器执行,减轻每台服务器的压力,从而提高了数据的吞吐量

  • 软硬件角度负载均衡的种类
    通过硬件来进行解决,常见的硬件有NetScaler、F5、Radware和Array等商用的负载均衡器,但比较昂贵的
    通过软件来进行解决,常见的软件有LVS、Nginx等,它们是基于Linux系统并且开源的负载均衡策略

  • 从端的角度负载均衡有两种
    服务端负载均衡
    客户端负载均衡

  • 常见的负载均衡策略(看组件的支持情况)
    节点轮询:每个请求按顺序分配到不同的后端服务器
    weight 权重配置:weight和访问比率成正比,数字越大,分配得到的流量越高
    固定分发:根据请求按访问ip的hash结果分配,这样每个用户就可以固定访问一个后端服务器
    随机选择、最短响应时间等等

2.AlibabaCloud集成Ribbon实现负载均衡

  • 什么是Ribbon
    Ribbon是一个客户端负载均衡工具,通过Spring Cloud封装,可以轻松和AlibabaCloud整合

  • 订单服务增加@LoadBalanced 注解

@SpringBootApplication
@EnableDiscoveryClient
public class OrderApplication {
    
    public static void main(String [] args){
        SpringApplication.run(OrderApplication.class,args);
    }
    
    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}
  • Video,VideoOrder实体类增加serverInfo字段记录服务器信息方便测试
  • 修改VideoController
@RestController
@RequestMapping("api/v1/video")
public class VideoController {

    @Autowired
    private VideoService videoService;

    @RequestMapping("find_by_id")
    public Object findVideoById(int videoId, HttpServletRequest request){
        Video video = videoService.findById(videoId);
        video.setServerInfo(request.getServerName()+":"+request.getServerPort());
        return video;
    }

}
  • 修改OrderController
@RestController
@RequestMapping("api/v1/video_order")
public class OrderController {
    @Autowired
    private RestTemplate restTemplate;
    @Autowired
    private DiscoveryClient discoveryClient;
    @RequestMapping("/save")
    public Object save(int videoId){
        //Video video = restTemplate.getForObject("http://localhost:9000/api/v1/video/find_by_id?videoId="+videoId, Video.class);
        //List<ServiceInstance> list =  discoveryClient.getInstances("xdclass-video-service");
        //ServiceInstance serviceInstance = list.get(0);
        Video video = restTemplate.getForObject("http://xdclass-video-service/api/v1/video/find_by_id?videoId="+videoId, Video.class);
        VideoOrder videoOrder = new VideoOrder();
        videoOrder.setVideoId(video.getId());
        videoOrder.setVideoTitle(video.getTitle());
        videoOrder.setCreateTime(new Date());
        videoOrder.setServerInfo(video.getServerInfo());
        return videoOrder;
    }
}
  • IDE设置启动多个video服务
    在这里插入图片描述在这里插入图片描述依次修改server端口进行启动
    在这里插入图片描述
  • postman进行测试
    在这里插入图片描述在这里插入图片描述
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值