SpringCloud(6)-Feign

SpringCloud(6)-Feign

简介

什么是Feign

Feign是声明式的web service客户端,它让微服务之间的调用变得更简单了,类似controller调用service。 SpringCloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端。
只需要创建一个接口, 然后添加注解即可!
feign,主要是社区,大家都习惯面向接口编程。这个是很多开发人员的规范。调用微服务访问两种方法

  1. 微服务名字[ribbon]
  2. 接口和注解[feign]

Fegin能做什么

Feign旨在使编写Java Http客户端变得更容易。
前面在使用Ribbon + RestTemplate时,利用RestTemplate对Http请求的封装处理,形成了一套模板化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用, 所以通常都会针对每个微服务自行封装-些客户端类来包装这些依赖服务的调用。 所以,Feign在此基础上做了进一步封装,由他来帮助我们定义和实现依赖服务接口的定义,在Feign的实现下,我们只需要创建一个接口并使用注解的方式来配置它(类似于以前Dao接口上标注Mapper注解,现在是一个微服务接口上面标注一个Feign注解即可),即可完成对服务提供方的接口绑定,简化了使用Spring Cloud Ribbon时,自动封装服务调用客户端的开发量。

Fegin集成了Ribbon

利用Ribbon维护了MicroServiceCloud-Dept的服务列表信息,并且通过轮询实现了客户端的负载均衡,而与
Ribbon不同的是,通过Feign只需要定义服务绑定接口且以声明式的方法,优雅而且简单的实现了服务调用。

如何使用

  1. 创建一个新的Maven Module :springcloud-consumer-dept-feign-80
  2. 复制springcloud-consumer-dept-80项目中的pom.xml,com.yinrz.springcloud包下所有内容,application.yml
  3. 给springcloud-api与springcloud-consumer-dept-feign-80的pom文件添加Feign依赖
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
  1. 在springcloud-api项目的com.yinrz.springcloud下新建service包,新建DeptService_Feign接口:
@FeignClient(value = "springcloud-provider-dept")
public interface DeptService_Feign {
    
    @GetMapping("/dept/all")
    List<Dept> queryAll();
    
    @GetMapping("/dept/get/{id}")
    Dept queryById(@PathVariable("id") long id);
    
    @PostMapping("/dept/add")
    boolean addDept(Dept dept);
}
  1. 修改springcloud-consumer-dept-feign-80项目中的controller包下的DeptConsumerController:
@RestController
public class DeptConsumerController {

    @Resource
    private DeptService_Feign deptServiceFeign; 

    @RequestMapping("/consumer/dept/all")
    public List<Dept> all(){
        return deptServiceFeign.queryAll();
    }
    @RequestMapping("/consumer/dept/get/{id}")
    public Dept get(@PathVariable("id") long id){
        return deptServiceFeign.queryById(id);
    }
    @RequestMapping("/consumer/dept/add")
    public boolean add(Dept dept){
        return deptServiceFeign.addDept(dept);
    }

}
  1. 修改springcloud-consumer-dept-feign-80项目中的主启动类:
@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients(basePackages = {"com.yinrz.springcloud"})
public class DeptConsumer_Feign_80 {
    public static void main(String[] args) {
        SpringApplication.run(DeptConsumer_Feign_80.class,args);
    }
}
  1. 启动Eureka服务器springcloud-eureka-7001,服务提供者springcloud-provider-dept-8001,springcloud-provider-dept-8002,springcloud-provider-dept-8003,服务消费者springcloud-consumer-dept-feign-80,访问http://localhost/consumer/dept/all测试,发现实现了负载均衡:

posted @ 2020-04-23 10:09  Baby丿太依赖  阅读(540)  评论(0)    收藏  举报