我正在尝试编译一个具有JDK9 9的新AOT特性的应用服务器,并面临许多挑战。
appserver由大约180 MB的jars组成,它一起编译溢出整数,所以我尝试将每个模块编译成一个(.so)库。这些模块依赖于其他模块,因此我不得不使用-J-cp -J依赖项将它们放到类路径上。这导致了4.4GB的libs --因为AOT应该加快服务器的启动速度,所以您可以想象从磁盘加载这个文件并没有多大帮助。(可以删除这些库的调试信息,但与jars相比,我们仍然在讨论规模增长的顺序。)
令我相当失望的是,jaotc实际上加载了编译过的类,这会触发静态构造函数(这有时会给我带来错误)。此外,编译器无法处理缺少的引用类,有时这只是一个运行时依赖关系-服务器在没有它们的情况下运行时也没有问题。因此,我必须提供空的模拟类来满足编译器。
但是,当使用AOT跟踪(-Xlog:aot+class+load=trace:file=/tmp/aot.txt:none,而不是stdout -XX:+PrintAOT)运行服务器时,我发现库也包含依赖项的某些部分:
found java.lang.Object in /home/user/aot/common/libjava.base-coop.so for classloader 0x2b5745e6ac80 tid=0x00002b574401e800
found java.lang.Object in /home/user/aot/appserver/lib/libcom.example.module1.so for classloader 0x2b5745e6ac80 tid=0x00002b574401e800
found java.lang.Object in /home/user/aot/appserver/lib/libcom.example.module2.so for classloader 0x2b5745e6ac80 tid=0x00002b574401e800这证实了我的疑虑,即库包含的不仅仅是我给编译器编译的jars中的代码,至少也包含了超类的代码。当JVM在多个库中找到相同的类时,我也不确定JVM的行为。
有可能剥去这些双重性吗?大/多库项目的推荐方法是什么?
https://stackoverflow.com/questions/46582922
复制相似问题