当前位置: 首页 > 面试题库 >

JVM为什么需要预热?

甘兴学
2023-03-14
问题内容

我知道在Java虚拟机(JVM)中,由于Java使用惰性加载过程加载类,因此可能需要进行预热,因此您要确保在启动主事务之前初始化对象。我是C
++开发人员,不必处理类似的要求。

但是,我无法理解的部分如下:

  1. 您应该预热代码的哪一部分?
  2. 即使我对代码的某些部分进行了预热,它也会保持多长时间(假设此术语仅意味着您的类对象在内存中保留了多长时间)?
  3. 如果每次收到事件都需要创建对象时,它有什么帮助?

考虑一个示例,该应用程序期望通过套接字接收消息,并且交易可以是“新订单”,“修改订单”和“取消订单”或已确认交易。

请注意,该应用程序是关于高频交易(HFT)的,因此性能至关重要。


问题答案:

您应该预热代码的哪一部分?

通常,您无需执行任何操作。但是,对于低延迟的应用程序,应预热系统中的关键路径。您应该有单元测试,所以我建议您在启动时运行它们以预热代码。

即使对代码进行了预热,也必须确保CPU缓存也保持预热。在执行阻塞操作(例如,网络IO)长达50微秒后,您会发现性能显着下降。通常这不是问题,但是如果您大部分时间都试图保持在50微秒以下,那么大多数情况下就会出现问题。

注意:预热可以允许Escape Analysis插入并在堆栈中放置一些对象。这意味着不需要优化这些对象。最好在优化代码之前先对应用程序进行内存分析。

即使我对代码的某些部分进行了预热,它也会保持多长时间(假设此术语仅意味着您的类对象在内存中保留了多长时间)?

没有时间限制。这取决于JIt是否检测到优化代码时所做的假设是否不正确。

如果每次收到事件都需要创建对象时,它有什么帮助?

如果您想要低延迟或高性能,则应创建尽可能少的对象。我的目标是产生小于300 KB
/秒的速度。使用此分配速率,您可以拥有足够大的伊甸园空间,每天可以收集一次。

考虑一个示例,该应用程序期望通过套接字接收消息,并且交易可以是“新订单”,“修改订单”和“取消订单”或已确认交易。

我建议您尽可能多地重用对象,尽管如果它在您的分配预算之内,则不必担心。

请注意,该应用程序是关于高频交易(HFT)的,因此性能至关重要。

您可能对我们的开源软件感兴趣,该软件可用于不同投资银行和对冲基金的HFT系统。

http://chronicle.software/

我的生产应用程序用于高频交易,每时每刻的延迟都是一个问题。很明显,在启动时,如果不对应用程序进行预热,将导致几毫秒的高延迟。

特别是您可能会对https://github.com/OpenHFT/Java-Thread-
Affinity
感兴趣,因为此库可以帮助减少关键线程中的调度抖动

而且据说需要预热的代码的关键部分(带有假消息)应至少运行12K次,以使其以优化的方式工作。为什么以及如何运作?

使用后台线程编译代码。这意味着,即使某个方法可能符合编译为本机代码的条件,但这并不意味着它在编译器已经非常忙的情况下已经在启动时这样做了。12K并非没有道理,但可能更高。



 类似资料:
  • 互联网是超文本标记语言(HTML)页面的集合,它们彼此链接以形成概念性信息网络。随着时间的推移,静态资源数量增加,图像等更丰富的项目开始成为Web结构的一部分。 高级服务器技术允许动态服务器页面 - 其内容基于查询生成的页面。 很快,需要拥有更多动态网页才能获得动态超文本标记语言(DHTML)。一切都归功于JavaScript。在接下来的几年中,我们看到了跨帧通信,试图避免页面重新加载,然后在帧内

  • 当前信息时代,哪里都是应用程序。这些应用程序们不仅仅是运行人们工作场所的工具 - 它们现在正在经营人们的生活。 对即时响应的需求,完美的行为和更多的功能是前所未有的。 而且,当然,人们期望应用程序在不同类型的设备上运行平稳,特别是在移动设备上。 应用程序执行的速度与它所做的一样重要。 NGINX的核心功能,例如其具有高性能HTTP和反向代理服务器的大规模可扩展事件驱动架构,访问和带宽控制以及与各种

  • 开发人员和运营工程师是两个不同的组织团队,如果发现这两个团队在错误的轨道上协作,则表明需要DevOps。以下是两个团队经常出现的一些问题: 在DevOps之前,开发和运营团队完全孤立。 测试和部署是在设计构建之后完成的独立活动。因此,他们比实际构建周期消耗更多时间。 在不使用DevOps的情况下,团队成员将大量时间花在测试,部署和设计上,而不是构建项目。 手动代码部署会导致生产中出现人为错误 编码

  • 我读了这篇文章“https://malloc.se/blog/zgc-jdk15,最后一个索引是关于

  • 有人问我这个问题,我只是回答“因为JVM需要移动对象”,但后来我搜索了一下,似乎找不到任何合理的答案。

  • 问题内容: 根据PreparedStatement.setNull的Java文档,“注意:您必须指定参数的SQL类型”。该方法需要列的SQL类型的原因是什么? 我注意到传递java.sql.Types.VARCHAR还可用于非varchar列。是否存在不适合使用VARCHAR的方案(某些列类型或某些数据库提供程序)? 谢谢。 问题答案: 根据PreparedStatement.setNull的Ja