如何知道在AMD64上建造的.jar是否会在手臂上完美运行?
我在 ARM 体系结构上的Docker中建立了一个.jar
, AMD64 上建立了。
两个.jar
文件具有相同的大小,但是vbindiff
说它们的内容完全不同。
我在我的AMD64计算机上测试了.jar
文件,并且“在任何地方构建,运行一次”。
我的假设是,这与 Java天然界面(JNI)有关。 .jar
是Spring Boot WebFlux后端。不幸的是,我不知道它或其他任何依赖性使用JNI。
我注意到手臂图像已安装 JDK 17.0.3 ,而AMD64映像具有 JDK 17.0.2。代码> .jar 使用 gradle包装器,它指定要下载并用于构建项目的确切工具链:
kotlin("jvm") version "1.6.10"
差异的原因是什么?我可以假设.jar
可以在具有兼容JVM的任何平台上使用吗?
编辑:我遵循托马斯的建议,并使用diff -r
比较.jar
文件的提取内容。他们是相同的。
但是,diff
确认.jar
文件本身不同。
我刚刚了解到,.jar
格式基于.zip
,它可以使用各种压缩方法,并在文件标头中包含其他信息,例如'最后修改'或可选的OS特异性属性。神秘解决了。
I built a .jar
in docker on the ARM architecture and one on AMD64.
The two .jar
files have the identical size, but vbindiff
says their contents are quite different.
I tested both .jar
files on my AMD64 computer and the reversed slogan "build anywhere, run once" holds.
My hypothesis is that this has to do with Java Native Interface (JNI). The .jar
is a Spring Boot Webflux backend. Unfortunately, I don't know if it or any other dependency uses JNI.
I noted that the ARM image has JDK 17.0.3 installed, while the AMD64 image has JDK 17.0.2. But this should not be a problem, since I built both .jar
s using the Gradle wrapper, which specifies the exact toolchain to be downloaded and used to build the project:
kotlin("jvm") version "1.6.10"
What could be the reason for the difference? Can I assume that either .jar
can be used on any platform that has a compatible JVM?
EDIT: I followed Thomas' advice and used diff -r
to compare the extracted contents of the .jar
files. They are identical.
However, diff
confirms that the .jar
files themselves are different.
I just learned that the .jar
format is based on .zip
, which can use various compression methods, as well as include extra information in file headers, such as 'last modified' or optional OS-specific attributes. Mystery solved.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您可以在
.jar
中使用jar tf myfile.jar
列出文件。如果唯一的内容是.class
文件和meta-inf/
中的清单数据,那么它是100%便携式的机会。如果您看到其他文件,例如.so
,.dll
或.dylib
,那么其中的本机代码可能会带来麻烦。您可以列出所有可能需要仔细查看的文件:
由于您已经在两个不同平台上构建了
.jar
s,因此您还可以使用jar xf myfile提取其内容。 jar
并使用diff -r
递归比较它们。尽管我认为.class
文件在语义上,这是一种比直接比较档案的更强大的检测差异的方法,尽管我认为.class
文件也可能不是相同的。You can list the files in the
.jar
usingjar tf myfile.jar
. If the only contents are.class
files and the manifest data inMETA-INF/
, then chances are good that it's 100% portable. If you see other files like.so
,.dll
or.dylib
, then there is native code in there which might give trouble.Here's how you can list all the files which might warrant a closer look:
Since you have already built the
.jar
s on two different platforms, you can also extract their contents usingjar xf myfile.jar
and usediff -r
to compare them recursively. This is a more robust way to detect differences than comparing the archives directly, although I imagine that.class
files might not be byte-wise identical either even if they're semantically the same.