Feign:SpringCloud的官网对它的定义是这样的:

是一个声明式的Web服务客户端。它支持Feign本身的注解、JAX-RS注解以及SpringMVC的注解。Spring Cloud集成Ribbon和Eureka以在使用Feign时提供负载均衡的http客户端。

Feign的使用

我们先来看一看如何在项目中使用Feign

1. 首先呢 ,我们把原先的cloud-demo-consumer项目复制一份,artifactId改为cloud-demo-consumer-feign,然后添加依赖 (温馨提醒,没有看过前几篇文章的朋友,建议先从第一篇文章开始学习效果更佳哦 每天学点SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud

        <dependency>
      <groupId>org.springframework.cloud</groupId>
      <!--注意此处的依赖是SpringBoot2.0以后专用的,如果您使用的SpringBoot版本低于2.0请使用spring-cloud-starter-feign-->
      <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

2.CloudDemoConsumerApplication启动类改名为CloudDemoConsumerFeignApplication,删除上次使用的RestTemplate,并在类上添加注解@EnableFeignClients,标示此项目为Feign客户端

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class CloudDemoConsumerFeignApplication { public static void main(String[] args) {
SpringApplication.run(CloudDemoConsumerFeignApplication.class, args);
}
}

3.在cn.org.zhixiang包下增加feign包 然后添加UserFeignClient接口:

@FeignClient("provider-demo")
public interface UserFeignClient {  @GetMapping (value = "/user/getUser/{id}")
 public User getUser(@PathVariable("id")Long id);
}

这个接口呢,就是我们使用Feign的关键了,我们先来看一下@FeignClient("provider-demo")注解,它括号里的内容 看着是不是很熟悉,这不就是我们的服务提供者的名称么,对其实它就是我们需要调用的服务的spring.application.name。

接着是@RequestMapping(value = "/user/getUser/{id}", method = RequestMethod.GET)

@PathVariable("id"),这个注解咋还写上value了呢,我记得没写过呀,其实这就是一个坑了,如果不写的话是启动不起来滴。

4.接着我们看UserController类,刚才我们已经把RestTemple的Bean给干掉了,那么在这断然没有在使用它的道理。

我们现在要使用的就是我们刚才定义的UserFeignClient 接口

@RestController
@RequestMapping("/user")
public class UserController {   @Autowired
  private UserFeignClient userFeignClient;   @GetMapping("/getUser/{id}")
  public User getUser(@PathVariable Long id){
     return userFeignClient.getUser(id);
  }
}

5现在我们就可以测试了,先启动Eureka服务,然后随便启动我们定义的两个服务提供者中的其中一个,最后启动我们的这个项目。

浏览器访问http://localhost:8089/user/getUser/1,不知道你获取到数据了么?

修改Feign的默认配置

修改Feign的默认配置其实也存在包扫描的问题,因为上一篇文章(自定义Eureka集群负载均衡策略)已经讲过了,这里就不浪费时间了,没有看过的同学可以先去参考一下。

这里我们就简单省事,把配置文件放到ComponentScan扫描不到的地方吧:cn.org.config,在这里呢,我们新建了Configuration配置类

@org.springframework.context.annotation.Configuration
public class Configuration {
@Bean
public Contract feignContract() {
return new Contract.Default();
}
}

然后在UserFeignClient类中指定configuration

@FeignClient(value = "provider-demo",configuration = Configuration.class)

注意,我们在此类中修改了Feign的Contract ,那么Contract 是什么呢。它叫做契约。因为Feign一开始使用的契约是SpringMVC,所以刚才我们SpringMVC的注解的时候直接成功了,但是你如果现在启动项目你就会发现已经启动不了了。因为Contract.Default()使用的契约是Feign自己的,也就是说我们要把SpringMVC的注解修改为Feign的注解

SpringMVC版本

@GetMapping (value = "/user/getUser/{id}")
public User getUser(@PathVariable("id")Long id);

Feign版本

@RequestLine("GET /user/getUser/{id}")
 public User getUser(@Param("id") Long id);

当你学会修改Feign的契约时修改别的默认同样不在话下了已经。

GitHub:https://github.com/shiyujun/spring-cloud-demo

如果对您有所帮助,请记得帮忙点一个star哦

本文出自https://zhixiang.org.cn/#/blog/read/9886acc8-96fa-4af0-9ab4-a99721474f51,转载请保留。

每天学点SpringCloud(四):Feign的使用及自定义配置的更多相关文章

  1. SpringCloud之Feign负载均衡(四)

    整合Feign pom.xml <dependency> <groupId>org.springframework.cloud</groupId> <arti ...

  2. SpringCloud 在Feign上使用Hystrix(断路由)

    SpringCloud  在Feign上使用Hystrix(断路由) 第一步:由于Feign的起步依赖中已经引入了Hystrix的依赖,所以只需要开启Hystrix的功能,在properties文件中 ...

  3. 每天学点SpringCloud(二):服务注册与发现Eureka

    相信看过 每天学点SpringCloud(一):简单服务提供者消费者调用的同学都发现了,在最后消费者调用提供者的时候把提供者的地址硬编码在了代码中,这样的方式肯定是不行的,今天,我们就是要Eureka ...

  4. Spring-Cloud之Feign声明式调用-4

    一.Feign受Retrofit.JAXRS-2.0和WebSocket影响,采用了声明式API 接口的风格,将Java Http 客户端绑定到它的内部. Feign 首要目的是将 Java Http ...

  5. [老老实实学WCF] 第四篇 初探通信--ChannelFactory

    老老实实学WCF 第四篇 初探通信--ChannelFactory 通过前几篇的学习,我们简单了解了WCF的服务端-客户端模型,可以建立一个简单的WCF通信程序,并且可以把我们的服务寄宿在IIS中了. ...

  6. 一步一步学ZedBoard & Zynq(四):基于AXI Lite 总线的从设备IP设计

    本帖最后由 xinxincaijq 于 2013-1-9 10:27 编辑 一步一步学ZedBoard & Zynq(四):基于AXI Lite 总线的从设备IP设计 转自博客:http:// ...

  7. 从零开始学Xamarin.Forms(四) Android 准备步骤(添加第三方Xamarin.Forms.Labs库)

    原文:从零开始学Xamarin.Forms(四) Android 准备步骤(添加第三方Xamarin.Forms.Labs库)  1.安装对应dll     Update-Package Xama ...

  8. SpringCloud使用Feign调用其他客户端带参数的接口,传入参数为null或报错status 405 reading IndexService#del(Integer);

    SpringCloud使用Feign调用其他客户端带参数的接口,传入参数为null或报错status 405 reading IndexService#del(Integer); 第一种方法: 如果你 ...

  9. SpringCloud(5)---Feign服务调用

    SpringCloud(5)---Feign服务调用 上一篇写了通过Ribbon进行服务调用,这篇其它都一样,唯一不一样的就是通过Feign进行服务调用. 注册中心和商品微服务不变,和上篇博客一样,具 ...

随机推荐

  1. 分析easyswoole3.0源码,Trace组件(四)

    前文,我们访问地址的时候服务端会输出类似trace信息.那么原理是什么呢?其实es3已经把这个独立出来作为单独组件了,名字叫做Trace组件 在demo里的调用原理是 EasySwooleEvent: ...

  2. (转)Java Web(一) Servlet详解!!

    https://www.cnblogs.com/whgk/p/6399262.html 这篇文章到上一篇,距离的有点遥远呀,隔了大概有两个月把,中间在家过了个年,哈哈~ 现在重新开始拾起,最近在看一本 ...

  3. Scrapy运行ImportError: No module named win32api错误

    windows系统上出现这个问题的解决需要安装Py32Win模块,更方便的做法是: pip install pypiwin32

  4. Finance财务软件(自定义报表专题)

    我们可以通过存储过程自定义报表 1.在菜单中新增报表菜单,这里的代码约束为报表对应存储过程名称,配置完成成后重启客户端生效 2.在自定义模板中适配存储过程入参,这里的功能键值为存储过程名称,字段键值与 ...

  5. iOS12 XCode10更新

    原因:libc++.tbd库取代了libstdc++.6.0.9.tbd库 解决方法:我在项目里去掉了libstdc++.6.0.9.tbd库 这个时候去编译还是会报错, 解决方法:Xcode-fil ...

  6. Python 3.6安装yaml时报"AttributeError: module 'pip' has no attribute 'main'"和“Non-zero exit code”错误

    1.Python 3.6安装yaml时一开始报AttributeError: module 'pip' has no attribute错误,根据网上提供的解决方法修改Pycharm安装目录D:\Pr ...

  7. 基于grafana+telegraf的服务器监控方案

    准备工作:安装InfluxDb 1 Windows 1.1 下载agent      https://dl.influxdata.com/telegraf/releases/telegraf-1.10 ...

  8. 动态库的链接和链接选项-L,-rpath-link,-rpath

    https://my.oschina.net/shelllife/blog/115958 链接动态库 如何程序在连接时使用了共享库,就必须在运行的时候能够找到共享库的位置.linux的可执行程序在执行 ...

  9. XBee® ZigBee 模块使用方法

    Digi的ZigBee模块简称S2,根据芯片版本的不同历史上分别有S2,S2B,S2C等,每次硬件平台升级,都会引入一个新的尾缀字母.历史版本中S2和S2B已经停产并被S2C替代.当前S2C是主流平台 ...

  10. ajax相关知识总结

    一.原生AJAX的兼容版本实现 function createXhr(){ var Xhr = null; //浏览器的判断 if(window.XMLHttpRequest){ //ie789 ch ...