开发者社区> 问答> 正文

如何实现负载均衡?

如何实现负载均衡?

展开
收起
小天使爱美 2020-03-27 11:49:08 2643 0
4 条回答
写回答
取消 提交回答
  • 最佳回答:

    可以使用阿里云负载均衡SLB实例

    官方帮助文档地址:阿里云帮助中心

    更多参考: 阿里云官方(新用户需官网注册查看)

    2021-11-17 20:01:15
    赞同 展开评论 打赏
  • 可以使用阿里云负载均衡SLB实例: https://www.aliyun.com/product/slb

    官方帮助文档地址:阿里云帮助中心

    更多参考: 阿里云官方(新用户需官网注册查看)

    2021-10-06 17:21:58
    赞同 展开评论 打赏
  • 可以使用阿里云负载均衡SLB实例:https://www.aliyun.com/product/slb

    2021-08-26 20:00:04
    赞同 1 展开评论 打赏
  • Spring Cloud 的负载均衡是通过 Ribbon 组件完成的, Ribbon 提供了客户端侧的软件负载均衡算法。Spring Cloud 中的 RestTemplate 和 Feign 客户端底层的负载均衡是通过 Ribbon 实现的,本章介绍如何在您的应用中实现 RestTemplate 和 Feign 的负载均衡用法。

    背景信息 Spring Cloud AliCloud Ans 集成了 Ribbon 的功能,AnsServerList 实现了 Ribbon 提供的 com.netflix.loadbalancer.ServerList 接口。

    这个接口是通用的,其它类似的服务发现组件列如 Nacos、Eureka、Consul、ZooKeeper 也都实现了对应的 ServerList 接口,列如 NacosServerList、 DomainExtractingServerList、ConsulServerList、ZookeeperServerList 等。

    实现该接口相当于接入了 Spring Cloud 负载均衡规范,这个规范是共用的。这也意味着,从 Eureka、Consul、ZooKeeper 等服务发现方案切换到 Spring Cloud Alibaba 方案,在负载均衡这个层面,无需修改任何代码,RestTemplate、FeignClient,包括已过时的 AsyncRestTemplate ,都是如此。

    下面介绍如何在您的应用中实现 RestTemplate 和 Feign 的负载均衡用法。

    说明 本地开发中主要描述开发中涉及的关键信息,如果您想了解完整的 Spring Cloud 程序,可下载 service-provider和 service-consumer。

    RestTemplate 和 Feign 的实现方式有所不同,下面将分别介绍。

    RestTemplate RestTemplate 是 Spring 提供的用于访问 REST 服务的客户端,提供了多种便捷访问远程 HTTP 服务的方法,能够大大提高客户端的编写效率。

    您需要在您的应用中按照下面的示例修改代码,以便使用 RestTemplate 的负载均衡。

    public class MyApp { // 注入刚刚使用 @LoadBalanced 注解修饰构造的 RestTemplate // 该注解相当于给 RestTemplate 加上了一个拦截器:LoadBalancerInterceptor // LoadBalancerInterceptor 内部会使用 LoadBalancerClient 接口的实现类 RibbonLoadBalancerClient 完成负载均衡 @Autowired private RestTemplate restTemplate;

    @LoadBalanced // 使用 @LoadBalanced 注解修改构造的 RestTemplate,使其拥有一个负载均衡功能
    @Bean
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
    
    // 使用 RestTemplate 调用服务,内部会使用负载均衡调用服务
    public void doSomething() {
        Foo foo = restTemplate.getForObject("http://service-provider/query", Foo.class);
        doWithFoo(foo);
    }
    
    ...
    

    }
    Feign Feign 是一个 Java 实现的 HTTP 客户端,用于简化 RESTful 调用。

    配合 @EnableFeignClients 和 @FeignClient 完成负载均衡请求。

    使用 @EnableFeignClients 开启 Feign 功能。 @SpringBootApplication @EnableFeignClients // 开启 Feign 功能 public class MyApplication { ... }
    使用 @FeignClient 构造 FeignClient。 @FeignClient(name = "service-provider") public interface EchoService { @RequestMapping(value = "/echo/{str}", method = RequestMethod.GET) String echo(@PathVariable("str") String str); }
    注入 EchoService 并完成 echo 方法的调用。 调用 echo 方法相当于发起了一个 HTTP 请求。 public class MyService { @Autowired // 注入刚刚使用 @FeignClient 注解修饰构造的 EchoService private EchoService echoService;

    public void doSomething() {
    // 相当于发起了一个 http://service-provider/echo/test 请求
        echoService.echo("test");
        }
    ...
    

    }
    结果验证 service-consumer和多个serveice-provider启动后,访问service-consumer提供的 URL 确认是否实现了负载均衡。

    RestTemplate 多次访问/echo-rest/rest-test查看是否转发到不同的实例。

    Feign 多次访问/echo-feign/feign-test查看是否转发到不同的实例。

    2020-03-27 11:56:38
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
阿里云网络-SLB负载均衡产品介绍 立即下载
大规模场景下KubernetesService 负载均衡性能 立即下载
负载均衡 ALB的云上可观测能力最佳实践 立即下载