5. Spring Cloud声明式服务调用,Feign(Finchley版本)

本文介绍了Spring Cloud Feign在Finchley版本中的使用,包括Feign的基础概念、启动注册中心和接口服务提供者实例,以及如何创建Feign服务消费者。Feign简化了Web服务客户端的编写,结合Ribbon实现了负载均衡。通过示例展示了如何配置和调用Feign服务接口。
摘要由CSDN通过智能技术生成
  • 项目地址完整例子传送门
  • 项目中用到模块:
  • 模块介绍:
    1. eureka-server-peer-awareness 提供注册中心的服务
    2. ribbon-client 启动多实例,并注册到注册中心,提供接口服务
    3. feign-consumer 注册到注册中心,扮演服务消费者的角色,集成了Ribbon负载均衡和Feign声明式服务调用客户端
  • 官方文档
    1.Feign介绍
    2.spring-cloud/OpenFeign官方项目

1.Feign介绍

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

2.启动注册中心和接口服务提供实例

注册中心:eureka-server-peer-awareness
提供接口服务实例:ribbon-client
如果对这两个项目不是很了解,见:Spring Cloud负载均衡,Ribbon(Finchley版本)

3.创建feign-consumer服务消费者

  • pom.xml文件中,创建feign服务消费者,引入spring-cloud-starter-openfeign依赖其中包含了ribbon的依赖,所以不用重复引入spring-cloud-starter-netflix-ribbon
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.friends</groupId>
    <artifactId>feign-consumer</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>feign-consumer</name>
    <description>Demo project for Spring Cloud</description>
    <parent>
        <groupId>org.friends</groupId>
        <artifactId>centralpark</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>
</project>


  • 启动类中FeignConsumerApplication.java,添加注解@EnableFeignClients,声明feign服务
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class FeignConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(FeignConsumerApplication.class, args);
    }
}
  • 添加对外服务的Controller类FeignConsumerController .java
@RestController
public class FeignConsumerController {
    @Autowired
    private FeignConsumerService feignConsumerService;

    @GetMapping("feignClient")
    public  String ribbonClient(){
        return  feignConsumerService.feignClient();

    }
}
  • 添加Feign的服务调用FeignConsumerService.java接口,注解@FeignClient标定需要调用的微服务名称,使用SpringMVC式注解@GetMapping等进行调用和参数绑定
@FeignClient("RibbonClient")
public interface FeignConsumerService {
    @GetMapping("ribbonClient")
    String feignClient();
}
  • 配置文件中application.yml中,配置注册中心
spring:
  application:
    name: FeignConsumer

eureka:
  client:
    serviceUrl:
      defaultZone: http://peer1:8887/eureka/,http://peer2:8888/eureka/,http://peer3:8889/eureka/
server:
  port: 8001
  • 启动消费者服务,访问注册中心面板http:peer1/8887 如下图,可见3个注册中心实例,2个接口提供者实例ribbon-client,1个服务消费者实例feign-consumer
  • 调用服务消费者接口实例
    访问 http://localhost:8001/feignClient接口,下面字符串交替出现,说明调用成功并且Ribbon负载也在起作用
    1. I’m ribbonClient: port is 8601
    2. I’m ribbonClient: port is 8602

上一篇:Spring Cloud负载均衡,Ribbon(Finchley版本)
下一篇:Spring Cloud 分布式配置中心入门 ,Spring Cloud Config(Finchley版本)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值