Springboot 微服务之间接口调用 @FeignClient

Springboot 微服务之间接口调用 @FeignClient

1.常见微服务调用方式

1.1使用httpClient请求
1.2使用RestTemplate方法
1.3使用Fegin方法(推荐)
参考:https://blog.csdn.net/ccblogger/article/details/103684004

2.Fegin调用方式(客户端)

2.1环境准备
2.1.1配置文件yaml/properties
注册中心地址
eureka.client.serviceUrl.defaultZone=http://ip:port/eureka/
说明:客户端微服务与服务端微服务必须注册到同一eureka

在这里插入图片描述

2.1.2启动类添加@EnableFeignClients注解
@SpringBootApplication(scanBasePackages = {"com.nari.osp.pbrtj"}) 
@EnableEurekaClient 
@EnableApolloConfig 
@EnableCaching
***@EnableFeignClients*** 
@EnableScheduling 
@EnableAsync 
public class ZdygzypApplication {

    public static void main(String[] args) {
        SpringApplication.run(ZdygzypApplication.class, args);
        }
}
2.1.3调用代码
通过@FeignClient(name = "服务名", path = "服务前缀")注解调用远程服务时
"服务名" 填写 远程服务配置的: spring.application. name=服务名
"服务前缀" 填写 远程服务配置的:server.servlet.context-path ,远程服务没有配置,path不用配置
@Component
@FeignClient(value = "XXX", path = "/XXX")
public interface SjzlgkfxClient {
    @RequestMapping(value = "/ZlgkController/getTrustReason", method = RequestMethod.POST)
    String getTrustReason(@RequestBody PbDataQuality pbDataQuality);
}
2.1.4pom文件引入依赖
<dependencies>
        <!--openfein的依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>2.1.3.RELEASE</version>
        </dependency>
    </dependencies>
2.3@FeignClient参数说明
name:指定FeignClient的名称,如果项目使用了Ribbon,name属性会作为微服务的名称,用于服务发现。
url: url一般用于调试,可以手动指定@FeignClient调用的地址。
decode404:当发生http 404错误时,如果该字段位true,会调用decoder进行解码,否则抛出FeignException。
configuration: Feign配置类,可以自定义Feign的Encoder、Decoder、LogLevel、Contract。
fallback: 定义容错的处理类,当调用远程接口失败或超时时,会调用对应接口的容错逻辑,fallback指定的类必须实现 @FeignClient标记的接口。
fallbackFactory: 工厂类,用于生成fallback类示例,通过这个属性我们可以实现每个接口通用的容错逻辑,减少重复的代码。
path: 定义当前FeignClient的统一前缀。
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值