Springboot 微服务之间接口调用 @FeignClient
1.常见微服务调用方式
1.1使用httpClient请求
1.2使用RestTemplate方法
1.3使用Fegin方法(推荐)
2.Fegin调用方式(客户端)
2.1环境准备
2.1.1配置文件yaml/properties
注册中心地址
eureka.client.serviceUrl.defaultZone=http://ip:port/eureka/
说明:客户端微服务与服务端微服务必须注册到同一eureka
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/2f66c87689fef8704957665516c55b83.png)
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的统一前缀。