微服务Spring Cloud—Feign简介和为服务消费者整合
Feign简介Feign是Netflix开发的声明式、模块化的HTTP客户端,其灵感来自Retrofit、JAXRS-2.0以及WebSocket。Feign可帮组我们更加便捷、优雅的调用HTTP API。在Spring Cloud中,使用Feign非常简单——创建一个接口,并在接口上添加一些注解,代码就完成了。Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。Spri...
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微服务架构实战》
更多推荐
所有评论(0)