Ribbon实现负载均衡调用服务

使用Ribbon实现负载均衡调用服务

1.Ribbon 服务调用

- 说明: 
	1.如果使用的是eureka client 和 consul client,无须引入依赖,因为在eureka,consul中默认集成了ribbon组件
	2.如果使用的client中没有ribbon依赖需要显式引入如下依赖
<!--引入ribbon依赖-->
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>

2.查看consul client中依赖的ribbon

依赖项中自行查看

3.使用restTemplate + ribbon进行服务调用

    - 使用discovery client  进行客户端调用(需要手动实现负载均衡)
          @Autowired
          private DiscoveryClient discoveryClient;

          //获取服务列表
          List<ServiceInstance> products = discoveryClient.getInstances("服务ID");
          for (ServiceInstance product : products) {
            log.info("服务主机:[{}]",product.getHost());
            log.info("服务端口:[{}]",product.getPort());
            log.info("服务地址:[{}]",product.getUri());
            log.info("====================================");
          }

    - 使用loadBalanceClient 进行客户端调用
          @Autowired
          private LoadBalancerClient loadBalancerClient;
          //根据负载均衡策略选取某一个服务调用
          ServiceInstance product = loadBalancerClient.choose("服务ID");
          log.info("服务主机:[{}]",product.getHost());
          log.info("服务端口:[{}]",product.getPort());
          log.info("服务地址:[{}]",product.getUri());

    - 使用@LoadBalanced     进行客户端调用
          //1.整合restTemplate + ribbon
          @Bean
          @LoadBalanced
          public RestTemplate getRestTemplate(){
            return new RestTemplate();
          }
          //2.调用服务位置注入RestTemplate
          @Autowired
          private RestTemplate restTemplate;
          //3.调用
          String forObject = restTemplate.getForObject("http://服务ID/hello/hello?name=" + name, String.class);
posted @ 2021-09-29 18:25  code-G  阅读(33)  评论(0编辑  收藏  举报