前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Feign的使用及自定义配置

Feign的使用及自定义配置

作者头像
Java学习录
发布2019-04-18 14:38:25
1.5K0
发布2019-04-18 14:38:25
举报
文章被收录于专栏:Java学习录

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

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

Feign的使用

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

  1. 首先呢 ,我们把原先的cloud-demo-consumer项目复制一份,artifactId改为cloud-demo-consumer-feign,然后添加依赖 (温馨提醒,没有看过前几篇文章的朋友,建议先从第一篇文章开始学习效果更佳哦 使用SpringBoot2.0整合SpringCloud
代码语言:javascript
复制
    <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客户端

代码语言:javascript
复制
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class CloudDemoConsumerFeignApplication {
   public static void main(String[] args) {
      SpringApplication.run(CloudDemoConsumerFeignApplication.class, args);
   }
}

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

代码语言:javascript
复制
@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 接口

代码语言:javascript
复制
@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配置类

代码语言:javascript
复制
@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版本

代码语言:javascript
复制
@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的契约时修改别的默认同样不在话下了已经。 点赞收藏转发好看再走呗!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java学习录 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
负载均衡
负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档