SpringCloud构建微服务之Feign声明式服务调用

淩亂°似流年 2021-11-19 14:48 555阅读 0赞

前言

在讲前面几篇文章的时候,消费者服务与提供者服务之间是利用RestTemplate进行通信的。这种方式是属于面向服务编程,那么在实际开发中,对服务依赖的客户端可能会有很多,每个客户端都需要对这些依赖的服务调用进行封装,大大增加的工作量。因此,SpringCloud就提供了一种解决方案,面向接口编程的声明式服务调用——Feign,只需简单的声明一下微服务接口,即可进行服务之间的通信,从而大大减轻的工作量。

什么是Feign?

Feign是一个声明式WebService客户端。使用Feign能让编写Web Service客户端更加简单, 它的使用方法是定义一个接口,然后在上面添加注解,同时也支持JAX-RS标准的注解。Feign也支持可拔插式的编码器和解码器。Spring CloudFeign进行了封装,使其支持了Spring MVC标准注解和HttpMessageConvertersFeign可以与EurekaRibbon组合使用以支持负载均衡。

官方介绍:http://projects.spring.io/spring-cloud/spring-cloud.html#spring-cloud-feign
GitHub:https://github.com/OpenFeign/feign
在这里插入图片描述
前面在使用RestTemplate时,利用RestTemplate对http请求的封装处理,形成了一套模版化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处, 往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用。 所以,Feign在此基础上做了进一步封装,由他来帮助我们定义和实现依赖服务接口的定义。在Feign的实现下, 我们只需创建一个接口并使用注解的方式来配置它(以前是Dao接口上面标注Mapper注解,现在是一个微服务接口上面标注一个Feign注解即可) ,即可完成对服务提供方的接口绑定,优雅而简单的实现了服务调用 ,简化了使用Spring cloud Ribbon时,自动封装服务调用客户端的开发量。

集成Feign

创建一个名称为spring-cloud-apimodule
在这里插入图片描述
修改pom文件,增加feign依赖:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <parent>
  6. <artifactId>spring-cloud-examples</artifactId>
  7. <groupId>com.chaytech</groupId>
  8. <version>1.0-SNAPSHOT</version>
  9. </parent>
  10. <modelVersion>4.0.0</modelVersion>
  11. <artifactId>spring-cloud-api</artifactId>
  12. <packaging>jar</packaging>
  13. <dependencies>
  14. <dependency>
  15. <groupId>com.chaytech</groupId>
  16. <artifactId>spring-cloud-model</artifactId>
  17. <version>${project.version}</version>
  18. </dependency>
  19. <dependency>
  20. <groupId>org.projectlombok</groupId>
  21. <artifactId>lombok</artifactId>
  22. </dependency>
  23. <!--feign-->
  24. <dependency>
  25. <groupId>org.springframework.cloud</groupId>
  26. <artifactId>spring-cloud-starter-feign</artifactId>
  27. </dependency>
  28. </dependencies>
  29. </project>

创建一个名称为UserApi的接口,并添加FeignClient注解:

  1. @FeignClient(value = "USER-PROVIDER")
  2. public interface UserApi {
  3. @PostMapping("/user/createUser")
  4. public boolean createUser(@RequestBody UserEntity user);
  5. @GetMapping("/user/getUser/{id}")
  6. public UserEntity getUser(@PathVariable("id") Integer id);
  7. @GetMapping("/user/listUser")
  8. public List<UserEntity> listUser();
  9. }

将此工程maven install,如果打包失败,找到父工程,maven install

创建feign客户端module(spring-cloud-consumer-user-feign):
在这里插入图片描述
spring-cloud-consumer-user的代码和配置文件copy一份到此工程下。
修改pom文件,增加feign依赖:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <parent>
  6. <artifactId>spring-cloud-examples</artifactId>
  7. <groupId>com.chaytech</groupId>
  8. <version>1.0-SNAPSHOT</version>
  9. </parent>
  10. <modelVersion>4.0.0</modelVersion>
  11. <artifactId>spring-cloud-consumer-user-feign</artifactId>
  12. <packaging>jar</packaging>
  13. <dependencies>
  14. <dependency>
  15. <groupId>com.chaytech</groupId>
  16. <artifactId>spring-cloud-model</artifactId>
  17. <version>${project.version}</version>
  18. </dependency>
  19. <dependency>
  20. <groupId>com.chaytech</groupId>
  21. <artifactId>spring-cloud-api</artifactId>
  22. <version>${project.version}</version>
  23. </dependency>
  24. <dependency>
  25. <groupId>org.springframework.boot</groupId>
  26. <artifactId>spring-boot-starter-web</artifactId>
  27. </dependency>
  28. <!-- ribbon相关-->
  29. <dependency>
  30. <groupId>org.springframework.cloud</groupId>
  31. <artifactId>spring-cloud-starter-eureka</artifactId>
  32. </dependency>
  33. <dependency>
  34. <groupId>org.springframework.cloud</groupId>
  35. <artifactId>spring-cloud-starter-ribbon</artifactId>
  36. </dependency>
  37. <dependency>
  38. <groupId>org.springframework.cloud</groupId>
  39. <artifactId>spring-cloud-starter-config</artifactId>
  40. </dependency>
  41. <!--feign-->
  42. <dependency>
  43. <groupId>org.springframework.cloud</groupId>
  44. <artifactId>spring-cloud-starter-feign</artifactId>
  45. </dependency>
  46. <!-- 修改后立即生效,热部署 -->
  47. <dependency>
  48. <groupId>org.springframework</groupId>
  49. <artifactId>springloaded</artifactId>
  50. </dependency>
  51. <dependency>
  52. <groupId>org.springframework.boot</groupId>
  53. <artifactId>spring-boot-devtools</artifactId>
  54. </dependency>
  55. </dependencies>
  56. </project>

修改UserController,将原有的RestTemplate调用方式修改为feign调用:

  1. @RestController
  2. public class UserController {
  3. @Autowired
  4. private UserApi userApi;
  5. @PostMapping("/consumer/user/add")
  6. public boolean add(UserEntity user) {
  7. return userApi.createUser(user);
  8. }
  9. @GetMapping("/consumer/user/getUser/{id}")
  10. public UserEntity get(@PathVariable("id") Integer id) {
  11. return userApi.getUser(id);
  12. }
  13. @GetMapping("/consumer/user/listUser")
  14. public List<UserEntity> list() {
  15. return userApi.listUser();
  16. }
  17. }

修改启动类,增加@EnableFeignClients注解:
此处注意,如果你的feign接口的包路径与feign客户端路径不一致,则需要指定basePackages,否则将会扫描不到feign接口,导致注入失败。

  1. @SpringBootApplication
  2. // 本服务启动后会自动注册进eureka服务中
  3. @EnableEurekaClient
  4. @EnableFeignClients(basePackages ={"com.chaytech.api"} )
  5. public class UserConsumerFeign80_Application {
  6. public static void main(String[] args) {
  7. SpringApplication.run(UserConsumerFeign80_Application.class,args);
  8. }
  9. }

测试

分别启动eureka集群、部门微服务集群、feign客户端服务

还是请求同一个地址:127.0.01:8080/consumer/user/listUser

在这里插入图片描述
接口正常返回数据,至此,集成feign进行声明式服务调用成功!

发表评论

表情:
评论列表 (有 0 条评论,555人围观)

还没有评论,来说两句吧...

相关阅读