Spring Feign超时设置深入了解
作者:小乞丐程序员 发布时间:2022-01-17 10:39:06
Feign其他功能-超时设置
Feign 底层依赖于 Ribbon 实现负载均衡和远程调用。
Ribbon默认1秒超时。
超时配置:
ribbon:
ConnectTimeout: 1000 #连接超时时间,毫秒
ReadTimeout: 1000 #逻辑处理超时时间,毫秒
在feign-consumer中设置超时时间(具体代码看上 Feign的快速入门)
server:
port: 9000eureka:
instance:
hostname: localhost # 主机名
client:
service-url:
defaultZone: http://localhost:8761/eureka
spring:
application:
name: feign-consumer # 设置当前应用的名称。将来会在eureka中Application显示。将来需要使用该名称来获取路径#设置Ribbon的超时时间
ribbon:
ConnectTimeout: 1000 #链接超时时间,默认1s
ReadTimeout: 3000 #逻辑处理的超时时间 默认1s
provider超时2s测试
Goods goods = goodsservice.findOne(id);
//当前现场睡眠2秒
try {
Thread.sleep( millis: 2000);
}catch (InterruptedException e) {
e.printStackTrace(); //java.net.SocketTimeoutException: Read timed out
}
goods.setTitle(goods.getTitle() + ":" + port);//将端口号,设置
Feign其他功能-日志记录
Feign 只能记录 debug 级别的日志信息。
logging:
level:
com.itheima: debug //包名
定义Feign日志级别Bean
@Bean
Logger.Level feignLoggerLevel() {
return Logger.Level.FULL;
}
启用该Bean:
@FeignClient(configuration = XxxConfig.class)
修改consumer
#设置当前的日志级别 debug,feign 只支持记录debug级别的日志
logging:
level:
com.itheima: debug
package com.itheima.consumer.config;
import feign.Logger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class FeignLogConfig {
/**
* NONE, 不记录
* BASIC, 记录基本的请求行,响应状态码数据
* HEADERS, 记录基本的请求行,响应状态码数据,记录响应头信息
* FULL 记录完整的请求,响应数据
* @return
*/
@Bean
public Logger.Level level(){
return Logger.Level.FULL;
}
}
package com.itheima.consumer.feign;
import com.itheima.consumer.config.FeignLogConfig;
import com.itheima.consumer.domain.Goods;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
/**
* feign声明式接口 发钱远程调用的
* String url = "http://FEIGN-PROVIDER/goods/findOne/"+id;
* // 3. 调用方法
* Goods goods = restTemplate.getForObject(url, Goods.class);
*
* 1 定义接口
* 2 接口上添加注解 @FeignClient 设置value属性为服务提供的 应用名称
* 3 编写调用接口,接口的声明规则和提供方接口保持一致
* 4 注入该接口对象,调用接口方法完成远程调用
*/
@FeignClient(value = "FEIGN-PROVIDER",configuration = FeignLogConfig.class)
public interface GoodsFeignClient {
@GetMapping("/goods/findOne/{id}")
public Goods findGoodsById(@PathVariable("id") int id);
}
来源:https://blog.csdn.net/qq_40432598/article/details/129484028


猜你喜欢
- 这篇文章主要介绍了如何使用Jenkins编译并打包SpringCloud微服务目录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有
- C#动态创建lambda表达式近日在使用了一下EF框架,在做多条件where查询的时候不知道怎么做,网上找了找,一开始用context.Da
- 虚拟摇杆在移动游戏开发中,是很常见的需求,今天我们在Unity中,使用UGUI来实现一个简单的虚拟摇杆功能。1.打开Unity,新创建一个U
- 前言Java 中常规的集合工具,相比大家都熟练于胸,但是如果说有一个集合类你不一定知道或者说肯定没用过,你相不相信呢?今天跟大家介绍的就是&
- 设置session有效时间的三种方式session的默认有效时间是30分钟(min)方法一使用java函数:session.setMaxIn
- 前言本文主要是将最近工作中遇到的一个问题进行总结分享,主要介绍的是如何让WebView中H5页面全屏播放视频。关于这个问题,做一下简单分析,
- 节能减排,从我做起。一款Android应用如果非常耗电,是一定会被主人嫌弃的。自从Android手机的主人用了你开发的app,一天下来,也没
- 先看一组加载效果图,有点粉粉的加载圈: 自定义这样的圆形加载圈还是比较简单的,主要是用到Canvans的绘制文本,绘制圆和绘制圆弧的api:
- /// <summary>/// 获取本机在局域网的IP地址/// </summary>/// <return
- 一、什么是单例模式?单例设计模式(Singleton Design Pattern)理解起来非常简单。一个类只允许创建一个对象(或者实例),
- 本文实例讲述了Android使用WebView.loadUri()打开网页的方法。分享给大家供大家参考,具体如下:程序如下所示:import
- 一、概念HttpClientAndroid 6中移除(API数量多扩展困难)。HttpURLConnection目前官方集成的。OKHttp
- 使用 replace 函数动态填充字符串String str="Hello {0},我是 {1},今年{2}岁"
- 说起EventTrigger事件触发器,它的使用可以说是无处不在,EventTrigger继承了很多的事件接口,这些接口对我们开发是十分有用
- 一、ArrayListArrayList是一个可以处理变长数组的类型,这里不局限于“数”组,ArrayList是一个泛型类,可以存放任意类型
- <?xml version="1.0" encoding="UTF-8" ?> <
- 本文实例讲述了C#图像处理之头发检测的方法。分享给大家供大家参考。具体如下://发色检测(YCbCr颜色空间)public Bitmap H
- abstract可以用来修饰类,方法,属性,索引器和时间,这里不包括字段. 使用abstrac修饰的类,该类只能作为其他类的基类,不能实例化
- 本文实例讲述了C#中派生类调用基类构造函数用法。分享给大家供大家参考。具体分析如下:这里的默认构造函数是指在没有编写构造函数的情况下系统默认
- 在JavaBeans中有这样的一个描述:当一些信息需要使用类似于字典嵌套字典再嵌套列表这种很深的结构来储存的时候,请改用类来储存。实际上,这