基于springboot服务间Feign调用超时的解决方案
解决springboot服务间Feign调用超时问题概述
1、起因
在完成项目功能需求的开发,经过自己测试以及通过测试组测试通过后,昨晚正式部署到线上环境进行正式运行前的最后一次的测试。但是在测试中,由A服务调用B服务接口时,***通过Feign调用(其实就是http请求,当A服务调用B服务时,如果不配置超时时间,那么A发出请求后,B应该立即响应,否则A服务会认为B已经断开连接)出现***连接超时的错误,错误信息:Read timed out…
2、原因
用idea开发debug模式调试代码时,在处理服务间调用时,由于debug模式调试代码花费一些时间,结果出现Fegin连接超时问题
3、解决方案
在springboot项目application.yml配置文件中添加
#解决跨服务问题
4、使用Feign的好处
首先我们的项目使用了SpringCloud技术,而Feign可以和SpringCloud技术无缝整合。并且,你一旦使用了Feign作为http客户端,调用远程的http接口就会变得像调用本地方法一样简单。
5、项目如何使用Feign
(1) 首先你得引入Feign依赖的jar包:
gradle依赖:
compile "org.springframework.cloud:spring-cloud-netflix-core:1.3.2.RELEASE"
Maven依赖:
(2) 在properties配置文件中配置要调用的接口的URL路径(域名部分)
url.xapi=http://xapi.xuebusi.com
(3) 声明要调用的远程接口
6、说明:
(1) @FeignClient 是Feign提供的注解,用于通知Feign组件对该接口进行代理(不需要编写接口实现),使用者可直接通过@Autowired注入。
(2) @RequestMapping 是Spring提供的注解,这里可以直接使用以前使用SpringMVC时用过的各种注解,唯一不同的是,这里只是把注解用在了接口上。
(3) 如果将Feign与Eureka组合使用,@FeignClient(name = “xapi”)意为通知Feign在调用该接口方法时要向Eureka中查询名为 xapi 的服务,从而得到服务URL,
(4) 但是远程的http接口并不是我们自己的,我们无法把它注册到Eureka中,所以这里我们就使用 url = “${url.xapi}” 把要调用的接口的url域名部分直接写死到配置文件中。
feign超时问题解决必杀技
1、配置中添加:
feign: hystrix: enabled: false
2、添加:
hystrix: command: default: execution: timeout: enabled: false
3、添加:
ribbon: ReadTimeout: 10000 ConnectTimeout: 10000
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。
相关推荐
-
SpringBoot整合OpenFeign的坑
目录 项目集成OpenFegin 集成OpenFegin依赖 实现远程调用 解决问题 问题描述 问题分析 问题解决 最近,在使用SpringBoot+K8S开发微服务系统,既然使用了K8S,我就不想使用SpringCloud了.为啥,因为K8S本身的就提供了非常6的服务注册与发现.限流.熔断.负载均衡等等微服务需要使用的技术,那我为啥还要接入SpringCloud呢?额,说了这么多,在真正使用SpringBoot+K8S这一套技术栈的时候,也会遇到一些问题,比如我不需要使用SpringCloud
-
SpringBoot如何使用feign实现远程接口调用和错误熔断
这篇文章主要介绍了SpringBoot如何使用feign实现远程接口调用和错误熔断,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.第一步,新建两个简单的springboot项目并创建rest接口 demo系统的rest接口 plus系统的调用接口 2.在项目pom文件里导入feign和hystrix的pom依赖包 <properties> <java.version>1.8</java.version> <s
-
springboot openfeign从JSON文件读取数据问题
对openfeign不清楚的同学可以参考下我的这篇文章:springboot~openfeign从此和httpClient说再见 对于openfeign来说,帮助我们解决了服务端调用服务端的问题,你不需要关心服务端的URI,只需要知道它在eureka里的服务名称即可,同时你与服务端确定了服务方法的参数和返回值之后,我们可以在单元测试时mock这些服务端方法即可,真正做到了单元测试,而不需要与外界资源进行交互. 今天主要说一下在openfeign里读取JSON文件的问题,我们将测试所需要的数据存储
-
从零开始学springboot整合feign跨服务调用的方法
介绍 微服务横行的互联网世界, 跨服务调用显得很平凡, 我们除了采用传统的http方式接口调用, 有没有更为优雅方便的方法呢? 答案是肯定的,feign就提供了轻便的方式! 如果你的服务都注册了注册中心,比如nacos, 那么调用会显得很轻松, 只需一个注解, 带上需要调用的服务名即可,**feign + nacos**会帮你做剩余的事. 如果没有注册中心, 也无需担心, feign一样可以以传统的 ip:port 方式进行调用~ 下面,我们来实践下吧 springboot整合feign 引入依
-
springboot FeignClient注解及参数
一.FeignClient注解 FeignClient注解被@Target(ElementType.TYPE)修饰,表示FeignClient注解的作用目标在接口上 @FeignClient(name = "github-client", url = "https://api.github.com", configuration = GitHubExampleConfig.class) public interface GitHubClient { @Request
-
SpringBoot使用Feign调用其他服务接口
使用SpringCloud的Feign组件能够为服务间的调用节省编码时间并提高开发效率,当服务本身不复杂时可以单独将该组件拿出使用. 引入依赖 <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-openfeign --> <dependency> <groupId>org.springframework.cloud</groupId>
-
SpringBoot工程下使用OpenFeign的坑及解决
一.前言 在SpringBoot工程(注意不是SpringCloud)下使OpenFeign的大坑.为什么不用SpringCloud中的Feign呢? 首先我的项目比较简单(目前只有login与业务模块)所以暂时不去引入分布式的架构,但两个服务之间存在一些联系因此需要接口调用接口(实现该操作方式很多我选择了OpenFeign,踩坑之路从此开始...). 二.具体的坑 使用OpenFeign我是直接参考官方的demo,官方的例子写的简洁明了直接套用到自己的工程中即可,自己也可以做相应的封装再调用但
-
基于springboot服务间Feign调用超时的解决方案
解决springboot服务间Feign调用超时问题概述 1.起因 在完成项目功能需求的开发,经过自己测试以及通过测试组测试通过后,昨晚正式部署到线上环境进行正式运行前的最后一次的测试.但是在测试中,由A服务调用B服务接口时,***通过Feign调用(其实就是http请求,当A服务调用B服务时,如果不配置超时时间,那么A发出请求后,B应该立即响应,否则A服务会认为B已经断开连接)出现***连接超时的错误,错误信息:Read timed out- 2.原因 用idea开发debug模式调试代码时,
-
webservice实现springboot项目间接口调用与对象传递示例
目录 一.百度百科 二.webservice的技术支持 1.XML和XSD 2.SOAP 3.WSDL 4.UDDI 5.调用RPC与消息传递 三.webservice的应用场景和弊端 1.webservice的应用场景 2.webservice的弊端 四.webservice代码实例 服务端项目代码 客户端项目代码: 一.百度百科 Web Service是一个平台独立的,低耦合的,自包含的.基于可编程的web的应用程序,可使用开放的XML(标准通用标记语言下的一个子集)标准来描述.发布.发现.
-
基于SpringBoot的Dubbo泛化调用的实现代码
目录 1.服务端定义 1.1 服务定义及实现 1.2 服务提供者配置 1.3 启动类 1.4 pom文件 2.消费端定义 2.1 Dubbo配置类 2.2 启动类 2.3 pom文件 3. 运行结果 4 .结论 5.改进 5.1 关于服务的实现 5.2 在服务端配置中增加代码 Dubbo的泛化调用不需要引入调用方的接口,只需要指定接口的全类名,就可以调用服务,一般用于框架集成.接下来就基于SpringBoot实现了Dubbo的泛化调用. 1.服务端定义 1.1 服务定义及实现 package c
-
基于SpringBoot服务端表单数据校验的实现方式
SpringBoot服务端表单数据校验 (SpringBoot高级) 一.实现添加用户功能 1 创建项目 2 修改POM文件 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http:
-
微服务通过Feign调用进行密码安全认证操作
微服务通过Feign调用进行密码安全认证 在项目中,微服务之间的通信也是通过Feign代理的HTTP客户端通信,为了保护我们的业务微服务不被其他非法未经允许的服务调用, 我们要进行访问授权配置! Feign是客户端配置,@FeignClient注解有个configuation属性,可以配置我们自定义的配置类,在此类中注入微服务认证拦截器 /** * 访问微服务需要密码 * @return */ @Bean public FeignBasicAuthRequestInterceptor reque
-
详解feign调用session丢失解决方案
最近在做项目的时候发现,微服务使用feign相互之间调用时,存在session丢失的问题.例如,使用Feign调用某个远程API,这个远程API需要传递一个鉴权信息,我们可以把cookie里面的session信息放到Header里面,这个Header是动态的,跟你的HttpRequest相关,我们选择编写一个拦截器来实现Header的传递,也就是需要实现RequestInterceptor接口,具体代码如下: @Configuration @EnableFeignClients(basePack
-
Feign调用全局异常处理解决方案
异常信息形如: TestService#addRecord(ParamVO) failed and no fallback available.: 对于failed and no fallback available.这种异常信息,是因为项目开启了熔断: feign.hystrix.enabled: true 当调用服务时抛出了异常,却没有定义fallback方法,就会抛出上述异常.由此引出了第一个解决方式. 解决方案: 自定义Feign解析器: import com.alibaba.fastj
-
微服务间调用Retrofit在Spring Cloud Alibaba中的使用
目录 前置知识 搭建 使用 集成与配置 服务间调用 服务限流 熔断降级 总结 前置知识 在微服务项目中,如果我们想实现服务间调用,一般会选择Feign.之前介绍过一款HTTP客户端工具Retrofit,配合SpringBoot非常好用!其实Retrofit不仅支持普通的HTTP调用,还能支持微服务间的调用,负载均衡和熔断限流都能实现.今天我们来介绍下Retrofit在Spring Cloud Alibaba下的使用,希望对大家有所帮助! SpringBoot实战电商项目mall(50k+star
-
SpringBoot 关于Feign的超时时间配置操作
目录 Feign的超时时间配置 feign 时间设置 Feign调用问题 \ 超时 1.项目结构 2.在其他微服务中 引入clientXX.jar 3.feign调用超时 Feign的超时时间配置 feign 时间设置 contextId: 可以指定为某个接口进行单独的超时设置 @FeignClient(value = "user",contextId ="device") public interface DeviceFeignService { @Request
随机推荐
- Ajax跨域代理访问网络资源的实现代码
- 用vbs实现定时运行web文件的方法
- tomcat虚拟路径的配置方法汇总
- Oracle 如何创建和使用全文索引
- JavaScript控制图片360度旋转代码
- 如何使用JS获取IE上传文件路径(IE7,8)
- 详解ASP.NET Core 之 Identity 入门(二)
- Zend Framework数据库操作方法实例总结
- 简单理解JavaScript中的封装与继承特性
- Android RecyclerView滚动定位
- sqlserver2008 拆分字符串
- JQuery与JS里submit()的区别示例介绍
- js中回调函数的学习笔记
- JS 实现计算器详解及实例代码(一)
- JavaScript插入动态样式实现代码
- asp.net BasePage类+Session通用用户登录权限控制
- javaScript年份下拉列表框内容为当前年份及前后50年
- 从内存地址解析Java的static关键字的作用
- C++中vector容器使用详细说明
- JsChart组件使用详解