Python 官方文档:入门教程 => 点击学习
概述: • Feign 是一个声明式的 REST 客户端,它用了基于接口的注解方式,很方便实现客户端配置。 • Feign 最初由 Netflix 公司提供
• Feign 是一个声明式的 REST 客户端,它用了基于接口的注解方式,很方便实现客户端配置。
• Feign 最初由 Netflix 公司提供,但不支持springMVC注解,后由 SpringCloud 对其封装,支持了springmvc注
解,让使用者更易于接受
首先在调用者的pom中加入如下坐标
<!--feign-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
然后在启动类上添加注解
@EnableFeignClients
以启用Feign
最后创建一个接口,方法参数映射全部按照我们要调用的那个controller写一个
value
的值是应用名称
@FeignClient(value = "eureka-provider")
@RequestMapping("/provider")
public interface FeignProviderUserController {
@GetMapping("/getUser/{id}")
public ResponseEntity<User> getUser(@PathVariable("id")String id);
}
然后我们将这个接口注入到我们要使用的地方,就可以直接调用那个方法了
@GetMapping("/FeignClientGetUser/{id}")
public ResponseEntity<User> FeignClientGetUser(@PathVariable("id") String id){
System.out.println("进入");
ResponseEntity<User> user = feignConsumerUserClient.getUser(id);
return user;
}
现在存在一个问题,就是按照应用名称调用的时候。取到的对象name是正确的,但是url却是Http://+name,并不是我们想要的http://+host+port+uri,
正在解决…
结果:{好吧需要ribbon}
Feign 底层依赖于 Ribbon 实现负载均衡和远程调用。
• Ribbon默认1秒超时。
• 超时配置:
在调用者的配置文件中加入
# 设置Ribbon的超时时间
ribbon:
ConnectTimeout: 1000 # 连接超时时间 默认1s 默认单位毫秒
ReadTimeout: 3000 # 逻辑处理的超时时间 默认1s 默认单位毫秒
logging:
level: debug #配置日志级别
如果报错Failed to bind properties under 'logging.level'
,是因为SpringBoot2.0.0以后的版本只支持如下这种配置,需要指定名称
logging:
level:
root: info #配置日志级别
到此这篇关于spring cloud-Feign服务调用的文章就介绍到这了,更多相关Spring Cloud-Feign服务调用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Spring Cloud-Feign服务调用的问题及处理方法
本文链接: https://www.lsjlt.com/news/154354.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0