Spring Cloud Feign

Spring Cloud Feign是一套基于Netflix Feign实现的声明式服务调用客户端。它使得编写Web服务客户端变得更加简单。我们只需要通过创建接口并用注解来配置它既可完成对Web服务接口的绑定。它具备可插拔的注解支持,包括Feign注解、JAX-RS注解。它也支持可插拔的编码器和解码器。Spring Cloud Feign还扩展了对Spring MVC注解的支持,同时还整合了Ribbon和Eureka来提供均衡负载的HTTP客户端实现。

下面,我们通过一个例子来展现Feign如何方便的声明对eureka-client服务的定义和调用。

动手试一试

下面的例子,我们将利用之前构建的eureka-server作为服务注册中心、eureka-client作为服务提供者作为基础。而基于Spring Cloud Ribbon实现的消费者,我们可以根据eureka-consumer实现的内容进行简单改在就能完成,具体步骤如下:

  • 根据eureka-consumer复制一个服务消费者工程,命名为:eureka-consumer-feign。在pom.xml中增加下面的依赖:
 

1

2

3

4

5

6

7

 

<dependencies>

...

<dependency>

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

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

</dependency>

</dependencies>

  • 修改应用主类。通过@EnableFeignClients注解开启扫描Spring Cloud Feign客户端的功能:
 

1

2

3

4

5

6

7

8

9

 

@EnableFeignClients

@EnableDiscoveryClient

@SpringBootApplication

public class Application {

public static void main(String[] args) {

new SpringApplicationBuilder(Application.class).web(true).run(args);

}

}

  • 创建一个Feign的客户端接口定义。使用@FeignClient注解来指定这个接口所要调用的服务名称,接口中定义的各个函数使用Spring MVC的注解就可以来绑定服务提供方的REST接口,比如下面就是绑定eureka-client服务的/dc接口的例子:
 

1

2

3

4

5

6

7

 

@FeignClient("eureka-client")

public interface DcClient {

@GetMapping("/dc")

String consumer();

}

  • 修改Controller。通过定义的feign客户端来调用服务提供方的接口:
 

1

2

3

4

5

6

7

8

9

10

11

12

 

@RestController

public class DcController {

@Autowired

DcClient dcClient;

@GetMapping("/consumer")

public String dc() {

return dcClient.consumer();

}

}

通过Spring Cloud Feign来实现服务调用的方式更加简单了,通过@FeignClient定义的接口来统一的生命我们需要依赖的微服务接口。而在具体使用的时候就跟调用本地方法一点的进行调用即可。由于Feign是基于Ribbon实现的,所以它自带了客户端负载均衡功能,也可以通过Ribbon的IRule进行策略扩展。另外,Feign还整合的Hystrix来实现服务的容错保护,在Dalston版本中,Feign的Hystrix默认是关闭的。待后文介绍Hystrix带领大家入门之后,我们再结合介绍Feign中的Hystrix以及配置方式。

在完成了上面你的代码编写之后,读者可以将eureka-server、eureka-client、eureka-consumer-feign都启动起来,然后访问http://localhost:2101/consumer ,来跟踪观察eureka-consumer-feign服务是如何消费eureka-client服务的/dc接口的,并且也可以通过启动多个eureka-client服务来观察其负载均衡的效果。

Spring Cloud构建微服务架构:服务消费(Feign)【Dalston版】相关推荐

  1. Spring Cloud构建微服务架构:分布式服务跟踪(整合zipkin)【Dalston版】

    通过上一篇<分布式服务跟踪(整合logstash)>,我们虽然已经能够利用ELK平台提供的收集.存储.搜索等强大功能,对跟踪信息的管理和使用已经变得非常便利.但是,在ELK平台中的数据分析 ...

  2. Spring Cloud构建微服务架构:服务容错保护(Hystrix断路器)

    断路器 断路器模式源于Martin Fowler的Circuit Breaker一文."断路器"本身是一种开关装置,用于在电路上保护线路过载,当线路中有电器发生短路时," ...

  3. Spring Cloud构建微服务架构(七)消息总线(续:Kafka)

    Spring Cloud Bus除了支持RabbitMQ的自动化配置之外,还支持现在被广泛应用的Kafka.在本文中,我们将搭建一个Kafka的本地环境,并通过它来尝试使用Spring Cloud B ...

  4. Spring Cloud构建微服务架构(五)服务网关

    通过之前几篇Spring Cloud中几个核心组件的介绍,我们已经可以构建一个简略的(不够完善)微服务架构了.比如下图所示: alt 我们使用Spring Cloud Netflix中的Eureka实 ...

  5. Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)【Dalston版】

    前言 在微服务架构中,我们将系统拆分成了一个个的服务单元,各单元应用间通过服务注册与订阅的方式互相依赖.由于每个单元都在不同的进程中运行,依赖通过远程调用的方式执行,这样就有可能因为网络原因或是依赖服 ...

  6. Spring Cloud构建微服务架构:服务容错保护(Hystrix断路器)【Dalston版】

    前言 在前两篇<Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)>和<Spring Cloud构建微服务架构:服务容错保护(Hystrix依赖隔离)&g ...

  7. Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)【Dalston版】 1

    前言 在微服务架构中,我们将系统拆分成了一个个的服务单元,各单元应用间通过服务注册与订阅的方式互相依赖.由于每个单元都在不同的进程中运行,依赖通过远程调用的方式执行,这样就有可能因为网络原因或是依赖服 ...

  8. Spring Cloud构建微服务架构:消息驱动的微服务(核心概念)【Dalston版】

    通过<Spring Cloud构建微服务架构:消息驱动的微服务(入门)>一文,相信大家对Spring Cloud Stream的工作模式已经有了一些基础概念,比如:输入.输出通道的绑定,通 ...

  9. Spring Cloud构建微服务架构-Hystrix断路器

    断路器 断路器模式源于Martin Fowler的Circuit Breaker一文."断路器"本身是一种开关装置,用于在电路上保护线路过载,当线路中有电器发生短路时," ...

  10. Spring Cloud构建微服务架构:分布式服务跟踪(整合logstash)【Dalston版】

    通过之前的<入门示例>,我们已经为两个由SpringCloud构建的微服务项目 trace-1和 trace-2引入了Spring Cloud Sleuth的基础模块 spring-clo ...

最新文章

  1. req.xhr在express中的应用
  2. android service使用handle,android中对Looper、HandlerThread、IntentService的理解及使用方法...
  3. 3、寻找三角形--百度2017春招
  4. linux命令行提示符居中,linux命令行学习(54):修改提示符
  5. Android笔记 帧动画
  6. html span标签 不换行(有时span带中文时候是可以自动换行的)
  7. linux路由内核实现分析(二)---FIB相关数据结构(1)
  8. OpenStack 存储服务 Cinder介绍和控制节点部署 (十三)
  9. os.path.exists判断文件是否存在
  10. java float 运算_java基础之float、double底层运算
  11. 【学习笔记】尚硅谷大数据项目之Flink实时数仓---DWD和DIM
  12. 关于ESP8266和ESP8285的对比
  13. 计算机专业简历教育背景怎么写,简历中的教育背景应该怎么写
  14. 【springboot】mybatis-generator配置
  15. Pyecharts亚马逊订单可视化
  16. 安卓系统怎么查找手机定位服务器,安卓手机丢了怎么查定位找手机
  17. 软件架构---微核架构
  18. reviewer中文_中文审稿意见怎么写
  19. Python 爬抖音
  20. 第二课 IDEA 的使用

热门文章

  1. Nagios安装部署与Cacti整合文档超精细版本
  2. JAVA数据库连接的另一种实现及简单的数据插入及显示
  3. 【转】iOS开发24:使用SQLite3存储和读取数据
  4. C# 使用正则表达式去掉字符串中的数字,或者去掉字符串中的非数字
  5. ASP 高亮显示不区分大小写的关键字
  6. 突破Outlook2003附件格式限制
  7. nagios学习笔记(一)
  8. librdkafka介绍文档与配置参数
  9. vs2008生成安装部署文件的步骤
  10. Flask-sqlalchemy连接数据库