Fegin的解析

115 阅读2分钟

这是我参与「掘金日新计划 · 6 月更文挑战」的第22天 ,点击查看活动详情

一、Feign

基本概念

  • Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。\

  • Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。\

  • Spring Cloud对Feign进行了增强,使Feign支持了Spring MVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。\

  • Spring Cloud Feign是基于Netflix feign实现,整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能外,还提供了一种声明式的Web服务客户端定义的方式。\

  • Spring Cloud Feign帮助我们定义和实现依赖服务接口的定义。在Spring Cloud feign的实现下,只需要创建一个接口并用注解方式配置它,即可完成服务提供方的接口绑定,简化了在使用Spring Cloud Ribbon时自行封装服务调用客户端的开发量。

二、实现服务调用

1、在调用端添加pom依赖

在statistics微服务中添加

可以删除之前添加的ribbon依赖,因为openfeign中封装了ribbon负载均衡

 

<!--服务调用-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

2、启动类添加注解

 

@EnableFeignClients

3、创建远程调用包和接口

创建client包和UcenterClient接口

@FeignClient注解用于指定从哪个服务中调用功能 ,名称与被调用的服务名保持一致。

@GetMapping注解用于对被调用的微服务进行地址映射。

@PathVariable注解一定要指定参数名称,否则出错

@Component注解防止,在其他位置注入UcenterClient时idea报错

 

package com.guli.statistics.client;
@Component
@FeignClient("guli-ucenter")
public interface UcenterClient {
    /**
     * 注意:一定要写成 @PathVariable("day"),圆括号中的"day"不能少
     * @param day
     * @return
     */
    @GetMapping(value = "/admin/ucenter/member/count-register/{day}")
    public R registerCount(@PathVariable("day") String day);
}

4、调用微服务

修改DailyService中的createStatisticsByDay方法,调用client中的接口

实现

 

@Autowired
private UcenterClient ucenterClient;
@Transactional(rollbackFor = Exception.class)
@Override
public void createStatisticsByDay(String day) {
    //删除已存在的统计对象
    ...
    //获取统计信息
    Integer registerNum = (Integer) ucenterClient.registerCount(day).getData().get("countRegister");
    ...
    //创建统计对象
    ...
}

5、Swagger测试

启动eureka、ucenter、statistics三个微服务

在swagger中测试

\

三、测试负载均衡