Spring Cloud(五)Feign负载均衡

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qwqw3333333/article/details/83178807

1 概述

1.1 介绍

Feign是一个声明式WebService客户端,使用方法时定义一个接口并在上面添加注解即可。Feign支持可拔插式的编码器和解码器。Spring Cloud对Feign进行了封装,使其支持SpringMVC和HttpMessageConverters。Feign可以与Eureka和Ribbon组合使用以支持负载均衡。

1.2 由来

  1. 大部分时间我们都能接受ribbon这种直接调用微服务的方式来获取服务:
private static final String REST_URL_PREFIX = "http://MICROSERVICE-DEPT/";
  1. 大家都习惯面向接口编程,比如WebServive,Dao,为了适应广大社区人员提出的面向接口编程原则出现了Feign:
  1. 微服务名字获取调用地址。
  2. 通过接口加注解获取所需服务。

2 案例

2.1 新建consumer feign服务

  1. 导入pom.xml
<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-feign</artifactId>
    </dependency>
</dependencies>
  1. 编写配置文件。
server:
  port: 80
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
    register-with-eureka: false    #作为消费者不提供服务,不应该注册自己
  1. 创建Feign远程调用接口。
@FeignClient(name= "spring-cloud-provider")
public interface HelloRemote {

    /**
     * 该抽象方法的注解、访问路径、方法签名要和提供服务的方法完全一致
     * @param name
     * @return
     */
    @RequestMapping(value = "/hello/{name}")
    String hello(@RequestParam(value = "name") String name);

}
  1. 编写controller。
@RestController
public class ConsumerController {

    @Autowired
    HelloRemote HelloRemote;
	
    @RequestMapping("/hello/{name}")
    public String index(@PathVariable("name") String name) {
        return HelloRemote.hello(name);
    }

}
  1. 编写主启动类。
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class SpringCloudConsumerFeignApplication80 {
    public static void main(String[] args) {
        SpringApplication.run(SpringCloudConsumerFeignApplication80.class, args);
    }
}
  1. 依次启动uereka、provider、consumer feign服务测试。
    测试结果证明Feign默认使用轮训负载均衡算法
    注意:spring-cloud-starter-feign 里面已经包含了 spring-cloud-starter-ribbon(Feign 中也使用了 Ribbon)
    源码地址

猜你喜欢

转载自blog.csdn.net/qwqw3333333/article/details/83178807