【问题标题】:Slow First call rest API springboot Jersey Eureka慢速第一次调用rest API springboot Jersey Eureka
【发布时间】:2020-01-02 20:58:14
【问题描述】:

我的应用程序是基于微服务架构EurekaRest API springboot +jersey

与以下调用相比,实例启动后的第一次调用速度较慢(即使我对结果进行了存根)。

第一次调用的例子:500ms,其他调用大约60-100ms。

谁能帮我解决这个问题?

【问题讨论】:

  • 您好 Faroukb,欢迎来到 StackOverflow。我在添加新行和突出显示一些名词方面改进了你的问题。您可以再次编辑以查看下次如何操作。你能放一些代码,以便我们对你的问题有所了解吗?
  • 默认情况下,应用程序在启动时未完全初始化。您需要设置load-on-startup 属性。你已经设置了吗?
  • 是的,我做到了,但我遇到了同样的问题。

标签: performance rest spring-boot jersey netflix-eureka


【解决方案1】:

这很可能与 JVM 预热有关。来自https://www.baeldung.com/java-jvm-warmup

向 Java Web 应用程序发出的第一个请求通常比进程生命周期内的平均响应时间慢很多。这个预热期通常可以归因于延迟类加载和即时编译。

【讨论】:

  • 谢谢Wim,但是在启动spring boot应用程序时没有解决方法来做这个初始化...
  • 我认为这与JVM加载类无关。 Spring 在启动期间实例化所有 bean。相反,我认为这与如何仅在第一次需要时创建消息解析器有关。有关详细信息,请参阅我的类似问题 stackoverflow.com/q/69760176/324531
  • 就我而言,数据库连接池在第一次请求时需要时间进行初始化。我在数据库字符串中添加了 minpoolsize=10,现在第一个请求与后续请求一样快。默认 minpoolsize 为 0。
猜你喜欢
  • 1970-01-01
  • 2023-03-13
  • 1970-01-01
  • 2021-10-28
  • 2014-06-29
  • 2016-02-06
  • 1970-01-01
  • 2021-02-01
  • 1970-01-01
相关资源
最近更新 更多