SpringCloud-Feign 第一次请求timeout问题

java.util.concurrent.TimeoutException: null
    at com.netflix.hystrix.AbstractCommand.handleTimeoutViaFallback(AbstractCommand.java:980) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.AbstractCommand.access$500(AbstractCommand.java:59) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.AbstractCommand$12.call(AbstractCommand.java:595) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.AbstractCommand$12.call(AbstractCommand.java:587) ~[hystrix-core-1.5.6.jar:1.5.6]
    at rx.internal.operators.OperatorOnErrorResumeNextViaFunction$4.onError(OperatorOnErrorResumeNextViaFunction.java:140) ~[rxjava-1.1.10.jar:1.1.10]
    at rx.internal.operators.OnSubscribeDoOnEach$DoOnEachSubscriber.onError(OnSubscribeDoOnEach.java:87) ~[rxjava-1.1.10.jar:1.1.10]
    at rx.internal.operators.OnSubscribeDoOnEach$DoOnEachSubscriber.onError(OnSubscribeDoOnEach.java:87) ~[rxjava-1.1.10.jar:1.1.10]
    at com.netflix.hystrix.AbstractCommand$HystrixObservableTimeoutOperator$1.run(AbstractCommand.java:1121) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.strategy.concurrency.HystrixContextRunnable$1.call(HystrixContextRunnable.java:41) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.strategy.concurrency.HystrixContextRunnable$1.call(HystrixContextRunnable.java:37) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.strategy.concurrency.HystrixContextRunnable.run(HystrixContextRunnable.java:57) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.AbstractCommand$HystrixObservableTimeoutOperator$2.tick(AbstractCommand.java:1138) ~[hystrix-core-1.5.6.jar:1.5.6]
    at com.netflix.hystrix.util.HystrixTimer$1.run(HystrixTimer.java:99) ~[hystrix-core-1.5.6.jar:1.5.6]
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) ~[na:1.8.0_101]
    at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:308) ~[na:1.8.0_101]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$301(ScheduledThreadPoolExecutor.java:180) ~[na:1.8.0_101]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:294) ~[na:1.8.0_101]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) ~[na:1.8.0_101]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) ~[na:1.8.0_101]
    at java.lang.Thread.run(Thread.java:745) [na:1.8.0_101]

2017-05-15 20:40:21.407  INFO 5108 --- [erListUpdater-0] c.netflix.config.ChainedDynamicProperty  : Flipping property: springcloud-userservcie.ribbon.ActiveConnectionsLimit to use NEXT property: niws.loadbalancer.availabilityFilteringRule.activeConnectionsLimit = 2147483647

#索性禁用Feign的Hystrixfeign.hystrix.enabled=false



Spring Cloud Starter Feign Ribbon Bootstrap AngularJS 是一个基于 Spring Cloud 的微服务架构项目,它整合了 Feign、Ribbon 和 AngularJS。以下是该项目的一些主要特点和组成部分: 1. **Feign**: Feign 是一个声明式的 Web 服务客户端,使得调用 HTTP 接口变得简单。通过定义一个接口并使用注解来描述请求Feign 会自动生成代码来实现这些请求。 2. **Ribbon**: Ribbon 是 Netflix 发布的负载均衡器,它可以与 Feign 结合使用,实现对多个服务实例的负载均衡。 3. **Bootstrap**: 在 Spring Cloud 中,Bootstrap 通常用于加载配置信息。在这个项目中,Bootstrap 可能用于加载一些全局配置或初始化一些资源。 4. **AngularJS**: AngularJS 是一个前端 JavaScript 框架,用于构建动态的单页面应用(SPA)。在这个项目中,AngularJS 可能用于开发前端界面,与后端的 Spring Cloud 服务进行交互。 5. **Spring Cloud Starter**: Spring Cloud Starter 是一组自动化配置的集合,简化了 Spring Cloud 应用程序的开发。在这个项目中,Spring Cloud Starter 提供了 Feign 和 Ribbon 的自动配置。 6. **项目结构**: 这个项目的结构可能包括以下几个部分: - `src/main/java`: 存放 Java 源代码文件。 - `src/main/resources`: 存放配置文件,如 application.yml 或 application.properties。 - `src/main/webapp`: 存放静态资源文件,如 HTML、CSS 和 JavaScript 文件。 - `src/test/java`: 存放单元测试代码。 - `pom.xml`: Maven 项目的配置文件,用于管理项目依赖和构建过程。 7. **依赖管理**: 在 pom.xml 文件中,可能会包含以下依赖: - Spring Boot Starter Web - Spring Cloud Starter OpenFeign - Spring Cloud Starter Netflix Ribbon - AngularJS (如果使用 Maven 进行前端依赖管理) 8. **示例代码**: 以下是一个简化的示例代码,展示了如何使用 Feign 和 Ribbon 进行服务调用: ```java @FeignClient(name = "service-name", configuration = FeignConfig.class) public interface ServiceClient { @RequestMapping(value = "/api/resource", method = RequestMethod.GET) String getResource(); } @Configuration public class FeignConfig { @Bean public IRule ribbonRule() { return new RoundRobinRule(); // 使用轮询策略进行负载均衡 } } @RestController public class MyController { @Autowired private ServiceClient serviceClient; @GetMapping("/my-endpoint") public String myEndpoint() { return serviceClient.getResource(); } } ``` 9. **注意事项**: 在使用 Spring Cloud Starter Feign Ribbon Bootstrap AngularJS 时,需要注意以下几点: - 确保所有依赖的版本兼容。 - 正确配置 Feign 和 Ribbon 的相关属性。 - 如果使用 AngularJS,确保前端代码与后端 API 正确对接。 - 处理可能出现的异常和错误情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值