如何解决在 Java Azure 函数中默认启用 JDK Hotspot C1 编译器并禁用 C2
Azure 函数 documentation 建议启用热点编译器 C1,默认情况下在 azure 函数中禁用 C2。这背后的原因是什么?我想同时启用 C1 和 C2 以利用热点编译器优化,但想知道它是否会导致 azure 函数出现任何问题,并因此添加了此默认行为。
以下是文档中给出的选项:
-XX:+TieredCompilation (To enable C1)
-XX:TieredStopAtLevel=1 (To disable C2)
解决方法
-XX:TieredStopAtLevel=1
实际上只启用 C1
编译器(通过禁用 C2
)。这样做的原因是启动时间更快,但显然会损害以后的优化。
Spring
的 spring-boot 插件和 bootRun
也采用了相同的模式,顺便说一句。
另一个原因是他们可以测量时间并看到由于这些函数只运行一次,C2
可能没有那个有益,但这只是一个猜测。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。