springcloud微服务实战 学习笔记三 服务消费者

本文介绍了三种实现微服务负载均衡的方法:使用LoadBalancerClient、Ribbon及Feign。通过具体的代码示例展示了如何配置这些组件,并在Spring Cloud环境中实现服务发现和服务调用。

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

###第一种方式LoadBalancerClient

  • 依赖

          <parent>
              <groupId>org.springframework.boot</groupId>
              <artifactId>spring-boot-starter-parent</artifactId>
              <version>1.5.4.RELEASE</version>
              <relativePath/> <!-- lookup parent from repository -->
          </parent>
          <properties>
              <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
              <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
              <java.version>1.8</java.version>
          </properties>
    
          <dependencies>
              <dependency>
                  <groupId>org.springframework.cloud</groupId>
                  <artifactId>spring-cloud-starter-eureka-server</artifactId>
              </dependency>
              <dependency>
                  <groupId>org.springframework.boot</groupId>
                  <artifactId>spring-boot-starter-web</artifactId>
              </dependency>
          </dependencies>
    
          <dependencyManagement>
              <dependencies>
                  <dependency>
                      <groupId>org.springframework.cloud</groupId>
                      <artifactId>spring-cloud-dependencies</artifactId>
                      <version>Dalston.SR1</version>
                      <type>pom</type>
                      <scope>import</scope>
                  </dependency>
              </dependencies>
          </dependencyManagement>
    
          <build>
              <plugins>
                  <plugin>
                      <groupId>org.springframework.boot</groupId>
                      <artifactId>spring-boot-maven-plugin</artifactId>
                  </plugin>
              </plugins>
          </build>
    复制代码
  • 配置文件

      spring.application.name=eureka-consumer
      server.port=3333
      #服务注册中心
      eureka.client.serviceUrl.defaultZone=http://localhost:1111/eureka/
    复制代码
  • application

      @EnableDiscoveryClient
      @SpringBootApplication
      public class Application {
      
          @Bean
          public RestTemplate restTemplate() {
              return new RestTemplate();
          }
      
          public static void main(String[] args) {
              new SpringApplicationBuilder(Application.class).web(true).run(args);
          }
      }
    复制代码
  • controller

      @RestController
      public class DemoController {
          Logger logger = LoggerFactory.getLogger(this.getClass());
          @Autowired
          LoadBalancerClient loadBalancerClient;
          @Autowired
          RestTemplate restTemplate;
          @GetMapping("/hello")
          public String hello(){
              ServiceInstance serviceInstance = loadBalancerClient.choose("eureka-client");
              logger.info("host:"+serviceInstance.getHost()+"---port:"+serviceInstance.getPort()+"---uri"+serviceInstance.getUri());
              String url = "http://"+serviceInstance.getHost()+":"+serviceInstance.getPort()+"/hello";
              String forObject = restTemplate.getForObject(url, String.class);
      
              return forObject;
          }
      
      }
    复制代码

###第二种方式Ribbon

  • 依赖 在一种方式下添加依赖

              <dependency>
                  <groupId>org.springframework.cloud</groupId>
                  <artifactId>spring-cloud-starter-ribbon</artifactId>
              </dependency>
    复制代码

配置文件修改端口号即可 修改Application.java,在RestTemplate上添加注解

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
复制代码

controller修改为

    @GetMapping("/hello2")
    public String hello2(){
        return restTemplate.getForObject("http://eureka-client/hello",String.class);
    }
复制代码

###第三种方式Feign

  • 依赖 在第一种方式下添加依赖

      <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>spring-cloud-starter-feign</artifactId>
      </dependency>
    复制代码

配置文件修改端口号即可

Application.java添加注解@EnableFeignClients支持Feign客户端

    @EnableFeignClients
    @EnableDiscoveryClient
    @SpringBootApplication
    public class Application {
    
        public static void main(String[] args) {
            new SpringApplicationBuilder(Application.class).web(true).run(args);
        }
    }
复制代码

创建一个接口 @FeignClient("eureka-client")设置使用的服务名称

    @FeignClient("eureka-client")
    public interface DemoService {
    
        @GetMapping("/hello")
        String hello();
    }
复制代码

controller

    @RestController
    public class DemoController {
    
        Logger logger = LoggerFactory.getLogger(this.getClass());
        @Autowired
        DemoService demoService;
        @GetMapping("/hello")
        public String hello(){
    
            return demoService.hello();
        }
    }
复制代码

三种方式可以混合使用,第二种方式因为将RestTemplate对象添加了注解,所以第一种方式就不能直接使用了,只能利用其它方式发送http请求获取数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值