SpringCloud 之Feign服务消费者

Posted const-

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud 之Feign服务消费者相关的知识,希望对你有一定的参考价值。

Feign简介

Feign是一个声明式的伪Http客户端,它使得写Http客户端变得更简单。使用Feign,只需要创建一个接口并注解。它具有可插拔的注解特性,可使用Feign 注解和JAX-RS注解。Feign支持可插拔的编码器和解码器。Feign默认集成了Ribbon,并和Eureka结合,默认实现了负载均衡的效果。

  • Feign 采用的是基于接口的注解
  • Feign 整合了ribbon,具有负载均衡的能力
  • 整合了Hystrix,具有熔断的能力

编写Feign服务

创建一个model工程作为服务消费者,即eureka-feign-client。
导入依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

在程序的启动类上加上@EnableFeignClients注解开启Feign的功能:

技术图片
 1 import org.springframework.boot.SpringApplication;
 2 import org.springframework.boot.autoconfigure.SpringBootApplication;
 3 import org.springframework.cloud.client.loadbalancer.LoadBalanced;
 4 import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
 5 import org.springframework.cloud.openfeign.EnableFeignClients;
 6 import org.springframework.context.annotation.Bean;
 7 import org.springframework.web.client.RestTemplate;
 8 
 9 @SpringBootApplication
10 @EnableEurekaClient
11 // 开启Feign的功能
12 @EnableFeignClients
13 public class EurekaFeignClientApplication 
14 
15     public static void main(String[] args) 
16         SpringApplication.run(EurekaFeignClientApplication.class, args);
17     
18 
View Code

配置文件application.yml如下:

server:
  port: 8083

spring:
  application:
    name: eureka-feign-client

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:9100/eureka/

定义一个feign接口,通过@FeignClient(“服务名”),来指定调用哪个服务。

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

// 申明这是一个Feign客户端,并且指明服务id
@FeignClient(value = "eureka-client")
public interface FeignClientInter 

    // 这里定义了类似于SpringMVC用法的方法,就可以进行RESTful方式的调用了
    @GetMapping(value = "/hello")
    String sayHelloFromClient();

通过上面定义的Feign客户端来消费服务。

 1 import com.yq.feign.service.FeignClientInter;
 2 import org.springframework.beans.factory.annotation.Autowired;
 3 import org.springframework.web.bind.annotation.GetMapping;
 4 import org.springframework.web.bind.annotation.RestController;
 5 
 6 @RestController
 7 public class HelloController 
 8 
 9     @Autowired(required = false)
10     FeignClientInter feignClientInter;
11 
12     @GetMapping("/feign")
13     public String demo() 
14         return feignClientInter.sayHelloFromClient();
15     
16 

 

测试:
技术图片

以上是关于SpringCloud 之Feign服务消费者的主要内容,如果未能解决你的问题,请参考以下文章

SpringCloud学习系列之二 ----- 服务消费者(Feign)和负载均衡(Ribbon)

SpringCloud 教程 之三 服务消费(Feign)

SpringCloud微服务云架构构建B2B2C电子商务平台之-Eureka服务消费Feign

springcloud之服务消费者(ribbon)

SpringCloud-服务的消费者(Feign)

企业级 SpringCloud 教程 服务消费者(Feign)