项目使用Spring cloud,nacos作为注册中心。RPC使用的Feign。

在项目第一次启动的时候,访问链接会很慢,然后再次访问就会正常。

原因:Feign默认使用了Ribbon作为负载,然而Ribbon的默认加载策略是懒加载。当第一次访问的时候,不仅会发送访问请求,还有初始化相关的服务。

解决方式:

官方给出的解释是饥饿加载相关服务:

  1.  
    ribbon.eager-load.enabled=true
  2.  
    ribbon.eager-load.clients=服务名

还有可以在服务端禁用ribbon的hystrix:

feign.hystrix.enabled=false

同样也可以起到作用。

 

spring cloud gateway中解决第一次请求失败的问题

 

在项目中使用spring cloud gateway之后中,发现第一次路由请求都会失败。

百度了一下,知道是hystix timeout的问题:

即Hystrix默认的超时时间是1秒,如果超过这个时间尚未响应,将会进入fallback代码。

而首次请求往往会比较慢(因为Spring的懒加载机制,要实例化一些类),这个响应时间可能就大于1秒了。

一般有三种解决方案:

1)延长hystix的连接超时时间,默认时间是1秒

//在Fegion服务的application配置文件中添加一下配置:
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds:5000


2)禁用hystix的超时时间

//在Fegion服务的application配置文件中添加一下配置:
hystrix.command.default.execution.timeout.enabled: false


3)直接禁用hystix

//在Fegion服务的application配置文件添加如下配置信息:
feign.hystrix.enabled: false

 

个人感觉第2/3方案都太简单粗暴了,后面也会出现其他问题,所以先试试第1个方案。

posted on 2022-05-17 09:45  lshan  阅读(1317)  评论(0编辑  收藏  举报