当前位置: 首页 > 编程笔记 >

SpringCloud之Feign示例详解

栾景胜
2023-03-14
本文向大家介绍SpringCloud之Feign示例详解,包括了SpringCloud之Feign示例详解的使用技巧和注意事项,需要的朋友参考一下

Feign简介

Feign 是一个声明web服务客户端,这便得编写web服务客户端更容易,使用Feign 创建一个接口并对它进行注解,它具有可插拔的注解支持包括Feign注解与JAX-RS注解,Feign还支持可插拔的编码器与解码器,Spring Cloud 增加了对 Spring MVC的注解,Spring Web 默认使用了HttpMessageConverters, Spring Cloud 集成 Ribbon 和 Eureka 提供的负载均衡的HTTP客户端 Feign.

声明式REST客户端:Feign

先要启动eureka_register_service工程(注册中心)和biz-service-0工程(服务生产者)

创建一个maven工程eureka_feign_client

pom.xml

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>1.4.3.RELEASE</version>

<relativePath/> <!-- lookup parent from repository -->

</parent>

<properties>

<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

<java.version>1.8</java.version>

</properties>

<dependencies>

  <dependency>

    <groupId>org.springframework.cloud</groupId>

    <artifactId>spring-cloud-starter-feign</artifactId>

  </dependency>

  <dependency>

    <groupId>org.springframework.cloud</groupId>

    <artifactId>spring-cloud-starter-eureka</artifactId>

  </dependency>

  <dependency>

    <groupId>org.springframework.boot</groupId>

    <artifactId>spring-boot-starter-web</artifactId>

  </dependency>

  <dependency>

    <groupId>org.springframework.boot</groupId>

    <artifactId>spring-boot-starter-test</artifactId>

    <scope>test</scope>

  </dependency>

</dependencies>

<dependencyManagement>

  <dependencies>

    <dependency>

  <groupId>org.springframework.cloud</groupId>

  <artifactId>spring-cloud-dependencies</artifactId>

  <version>Brixton.SR5</version>

  <type>pom</type>

  <scope>import</scope>

</dependency>

  </dependencies>

</dependencyManagement> 

在应用主类中通过@EnableFeignClients注解开启Feign功能

启动文件FeignApplication.java

@SpringBootApplication

@EnableDiscoveryClient

@EnableFeignClients

public class FeignApplication {

  public static void main(String[] args) {

    SpringApplication.run(FeignApplication.class, args);

  }
}

定义服务接口类UserClient.java

使用@FeignClient("biz-service-0")注解来绑定该接口对应biz-service-0服务

@FeignClient("biz-service-0")

public interface UserClient { 

  @RequestMapping(method = RequestMethod.GET, value = "/getuser")

  public User getuserinfo();   

  @RequestMapping(method = RequestMethod.GET, value = "/getuser")

  public String getuserinfostr();   

  @RequestMapping(method = RequestMethod.GET, value = "/info")

  public String info();
} 

在web层中调用上面定义的UserController,具体如下

@RestController

public class UserController {

  @Autowired

  UserClient userClient;

  @RequestMapping(value = "/getuserinfo", method = RequestMethod.GET)

  public User getuserinfo() {

    return userClient.getuserinfo();

  }

  @RequestMapping(value = "/getuserinfostr", method = RequestMethod.GET)

  public String getuserinfostr() {

    return userClient.getuserinfostr();
  }

  @RequestMapping(value = "/info", method = RequestMethod.GET)

  public String info() {

    return userClient.info();

  }
} 

application.properties配置变量

spring.application.name=feign-consumer

server.port=8004

eureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/ 

访问 http://127.0.0.1:8004/getuserinfo

总结:

其实通过Feign封装了HTTP调用服务方法,使得客户端像调用本地方法那样直接调用方法,类似Dubbo中暴露远程服务的方式,区别在于Dubbo是基于私有二进制协议,而Feign本质上还是个HTTP客户端

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍详细介绍SpringCloud之Ribbon,包括了详细介绍SpringCloud之Ribbon的使用技巧和注意事项,需要的朋友参考一下 一:Ribbon是什么? Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一起。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简单的说,就是在配置文件中列出Lo

  • 本文向大家介绍详解SpringCloud Gateway之过滤器GatewayFilter,包括了详解SpringCloud Gateway之过滤器GatewayFilter的使用技巧和注意事项,需要的朋友参考一下 在Spring-Cloud-Gateway之请求处理流程文中我们了解最终网关是将请求交给过滤器链表进行处理,接下来我们阅读Spring-Cloud-Gateway的整个过滤器类结构以及

  • 本文向大家介绍SpringCloud项目集成Feign、Hystrix过程解析,包括了SpringCloud项目集成Feign、Hystrix过程解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了SpringCloud项目集成Feign、Hystrix过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Feign的功能:这是个消

  • 本文向大家介绍SpringCloud使用Feign实现服务调用,包括了SpringCloud使用Feign实现服务调用的使用技巧和注意事项,需要的朋友参考一下 Spring Cloud Feign简介 Spring Cloud Feign也是一个基础工具类,它整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能以外,它还提供了一种声明式的

  • 本文向大家介绍springcloud集成zookeeper的方法示例,包括了springcloud集成zookeeper的方法示例的使用技巧和注意事项,需要的朋友参考一下 为什么使用zookeeper Zookeeper 作为一个分布式的服务框架,主要用来解决分布式集群中应用系统的一致性问题,它能提供基于类似于文件系统的目录节点树方式的数据存储, Zookeeper 作用主要是用来维护和监控存储的

  • 本文向大家介绍详解spring security之httpSecurity使用示例,包括了详解spring security之httpSecurity使用示例的使用技巧和注意事项,需要的朋友参考一下 httpSecurity 类似于spring security的xml配置文件命名空间配置中的<http>元素。它允许对特定的http请求基于安全考虑进行配置。默认情况下,适用于所有的请求,但可以使用