开源框架-SpringCloud系列Spring Cloud

SpringCloud-Feign:详解Feign,接口式微服务

2020-06-20  本文已影响0人  CryFace

什么是Feign?

Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。它将微服务之间的调用变得更简单了,类似于controller调用service。

我们调用微服务访问有两种方法,一种是之前我们用RestTemplate的微服务名字来访问(Ribbon),一种就是我们的接口与注解(Feign)。

Feign能干什么?

我们主要用Feign来干什么呢?

Feign的核心就是动态代理,这是Feign的关键机制。

配置使用Feign

这里我继续以我之前SpringCloud的项目为例,来演示。

为了区别之前使用RestTemplate的消费者模块,这里我们再新建一个Feign的消费者模块。很多内容都不变,只需要改几个点

我们导入Feign的依赖

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-feign</artifactId>
        <version>1.4.6.RELEASE</version>
    </dependency>

同时我们创建一个接口,用来封装调用注册的微服务。需要注意的是声明方法的注解、方法签名要和提供服务的方法完全一致

我们@FeignClient后面的name是我们微服务模块注册的服务名字。

然后在我们的服务消费模块这里的Controller层这里,我们将Feign的service注入实例,就可以调用了。

@RestController
public class UserControllerConsumer {

    @Autowired
    private UserFeignService userFeignService;


    @RequestMapping("/consumer/user/get/{id}")
    public User get(@PathVariable int id){
        return userFeignService.queryUserById(id);
    }

    @RequestMapping("/consumer/user/list")
    public List<User> queryList(){
        return userFeignService.queryListUser();
    }

    @RequestMapping("/consumer/user/add")
    public boolean addUser(User user){
        return userFeignService.addUser(user);
    }
    
}

最后还需要在服务消费模块这里的主启动类开启我们的Feign,并且扫描我们另一个模块下的Feign服务。

@EnableEurekaClient
@EnableFeignClients("com.lin.springcloud")
@SpringBootApplication
public class Consumer_feign {
    public static void main(String[] args) {
        SpringApplication.run(Consumer_feign.class,args);
    }
}

需要注意的是,上面我因为这样写,报错了,找了近二十分钟的bug。

    @GetMapping("/user/get/{id}")
    public User queryUserById(@PathVariable int id);

如果没有Feign的话,这样写是可以的,但是在Feign里面的服务接口里面是不可以的,要改成这样

    @GetMapping("/user/get/{id}")
    public User queryUserById(@PathVariable(value = "id") int id);

感谢参考解决bugFeign PathVariable annotation was empty on param 0.

然后我们依次启动服务器,是可以取出数据的。

Feign 是怎么和 Ribbon、Eureka 整合的?

参考资料

阿提说说

上一篇下一篇

猜你喜欢

热点阅读