Feign简介

Feign是Netflix开发的声明式、模块化的HTTP客户端,其灵感来自Retrofit、JAXRS-2.0以及WebSocket。Feign可帮组我们更加便捷、优雅的调用HTTP API。

在Spring Cloud中,使用Feign非常简单——创建一个接口,并在接口上添加一些注解,代码就完成了。Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。

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

为服务消费者整合Feign

1.复制项目mcroservice-consumer-movie,将ArtifactId修改为microservice-consumer-movie-feign。

2.添加Feign依赖。

	<dependency>
    	<groupId>org.springframework.cloud</groupId>
    	<artifactId>spring-cloud-starter-openfeign</artifactId>
    	<version>2.0.2.RELEASE</version>
	</dependency>

3.创建一个Feign接口,并添加@FeignClient注解。

@FeignClient(name="users")
public interface UserFeignClient {
    @RequestMapping(value ="/{id}",method = RequestMethod.GET)
    public User findById(@PathVariable("id") Long id);
}

@FeignClient注解中的users是一个任意客户端名称,浴室创建Ribbon负载均衡器,由于使用了Eureka,所以Ribbon会把users解析成Eureka Server服务注册表内的服务。当然,如果不想使用Eureka,可使用service.ribbon.listOfServers属性配置服务器列表。

4.修改Controller,让其调用Feign接口

    @Autowired
    private UserFeignClient userFeignClient;

    @GetMapping("/user/{id}")
    public User findById(@PathVariable Long id){
        return this.userFeignClient.findById(id);
    }

5.修改启动类,添加@EnableFeignClients注解

@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients
public class ConsumerMovieApplication {
    @Bean
    public RestTemplate restTemplate() { return new RestTemplate(); }
    public static void main(String[] args) {
        SpringApplication.run(ConsumerMovieApplication.class, args);
    }
}

测试

1.启动microservice-discovery-eureka。
2.启动2个或者多个microservice-provider-user示例。
3.多次访问http://localhost:8010/user/1,返回如下结果。
在这里插入图片描述

两个微服务打印如下日志
在这里插入图片描述

本文大部分内容转载自周立的《Spring Cloud与Docker微服务架构实战》

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐