Spring Cloud OpenFeign深入浅出

本文详细介绍了Spring Cloud OpenFeign的使用,从简单玩法到高级配置,包括@FeignClient、Decoder、Encoder、Retryer、Feign.Builder、FeignLoggerFactory、Hystrix集成及故障转移机制。通过实例展示了如何进行服务调用、自定义配置以及异常处理。
摘要由CSDN通过智能技术生成


OpenFeign的README是Feign makes writing java http clients easier,让写java http clients更容易。所以不仅是Spring cloud生态用到,只要用到Http Client的地方都可以用它。

​ 这里我们一起感受一下Spring Cloud OpenFeign的便捷功能。

1. 简单玩法

1.1 一个简单例子

(1)服务端:

@RestController
@RequestMapping("hello")
public class HelloController implements HelloApi {
   
    @Override
    public String hello(String name) {
   
        return "Hello, "+name+"!";
    }
}

API声明:

public interface HelloApi {
   

    @GetMapping("/hello/{name}")
    String hello(@PathVariable("name") String name);

    @GetMapping("/bye/{name}")
    ResponseValue<String> bye(@PathVariable("name") String name);

    @GetMapping(value = "/download")
    byte[] download(HttpServletResponse response);
}

(2)客户端:

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

开启配置 @EnableFeignClients,调用服务的代码:

@FeignClient(name="hello1", url = "127.0.0.1:8080", path = "hello")
public interface HelloApiExp extends HelloApi {
   
    @GetMapping("/download")
    Response download();
}

调用时的代码:

@RestController
@RequestMapping("client")
public class HelloClient {
   

    @Autowired
    private HelloApiExp helloApi;

    @GetMapping("/hello/{name}")
    public String hello(@PathVariable("name") String name){
   
        return helloApi.hello(name);
    }
}    

浏览器访问URL:http://127.0.0.1:8080/client/hello/Mark,页面返回: Hello, Mark!

1.2 @FeignClient的简单用法

属性名称 属性说明 默认值
name/value 作为serviceId,bean name
contextId 作为bean name,代替name/value的值
qualifier 限定词
url http的URL前缀(不包括协议名):主机名和端口号
decode404 请求遇到404则抛出FeignExceptions false
path 服务前缀,等同于ContextPath
primary whether to mark the feign proxy as a primary bean true

2. 高级玩法

2.1 configuration配置类

通过自定义配置类统一配置Feign的各种功能属性,FeignClientsConfiguration为默认配置:

@FeignClient(name="hello1", url = "127.0.0.1:8080", configuration = FeignClientsConfiguration.class)
public interface HelloApi {
   
    @GetMapping("/{name}")
    String hello(@PathVariable("name") String name);
}

2.1.1 Decoder feignDecoder

Decoder类,将http返回的Entity字符解码(反序列化)为我们需要的实例,如自定义的POJO对象。一般使用FeignClientsConfiguration默认的feignDecoder就能满足返回String、POJO等绝大多数场景。

@Bean
@ConditionalOnMissingBean
public Decoder feignDecoder() {
   
	return new OptionalDecoder(
		new ResponseEntityDecoder(new SpringDecoder(this.messa
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值