1

我在使用 maven-assembly-plugin 创建更大的 zip 程序集(未压缩超过 3GB)时遇到问题。构建输出 zip 文件(压缩小于 1GB)时会出现问题。使用选项运行 maven 可以-e为我提供更详细的信息:

[INFO] Building zip: xxx/HG19-UCSC-dist.zip
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 12:40.199s
[INFO] Finished at: Wed Oct 02 11:08:44 BST 2013
[INFO] Final Memory: 13M/723M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-assembly-plugin:2.2-beta-5:single (make-assembly) on project HG19: Execution make-assembly of goal org.apache.maven.plugins:maven-assembly-plugin:2.2-beta-5:single failed: invalid entry size -> [Help 1]
...
...
...
Caused by: org.apache.maven.plugin.PluginExecutionException: Execution make-assembly of goal org.apache.maven.plugins:maven-assembly-plugin:2.2-beta-5:single failed: invalid entry size
    at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:115)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
    ... 19 more
Caused by: java.lang.IllegalArgumentException: invalid entry size
    at java.util.zip.ZipEntry.setSize(ZipEntry.java:135)
    at org.codehaus.plexus.archiver.zip.ZipOutputStream.closeEntry(ZipOutputStream.java:352)
    at org.codehaus.plexus.archiver.zip.ZipOutputStream.finish(ZipOutputStream.java:316)

环顾四周,我发现问题出在我的 JDK/JRE ( https://blogs.oracle.com/xuemingshen/entry/zip64_support_for_4g_zipfile ) 中缺少对 Zip64 的支持,该支持是 2011 年添加到 OpenJDK 的。

但是,我已将我的 JDK 更新为 Oracle 提供的最新版本:

$ mvn -version
Apache Maven 3.1.0 (893ca28a1da9d5f51ac03827af98bb730128f9f2; 2013-06-28 03:15:32+0100)
Maven home: /usr/local/apache-maven-3.1.0
Java version: 1.7.0_40, vendor: Oracle Corporation
Java home: /usr/local/java/jdk1.7.0_40/jre
Default locale: en_GB, platform encoding: ISO-8859-1
OS name: "linux", version: "2.6.32-279.2.1.el6.x86_64", arch: "amd64", family: "unix"

它再次报告了同样的问题。最新的 Oracle JDK 是否不支持 Zip64 或其他?

我想,我可以尝试从源代码构建 OpenJDK b147,但除非不可避免,否则我想避免这种情况。

4

4 回答 4

6

我找到了罪魁祸首,所以报告这个问题只是为了节省其他人的时间。

似乎问题在于org.codehaus.plexus.archiver.zip.ZipOutputStream.closeEntry(ZipOutputStream.java:352)我的异常堆栈跟踪中报告的问题。org.codehaus...ZipOutputStream.closeEntry查看我可以看到的来源:

entry.setSize( def.getTotalIn() );

def就是java.util.zip.Deflater。但是,Deflater.getTotalIn返回intlong。相反,应该使用Deflater.getBytesRead()我将向开发人员报告的代码。

2.5[编辑] 已经有一段时间了,但我看到人们在阅读这篇文章,所以仅供参考,自maven 程序集插件版本以来问题已得到修复。

于 2013-10-02T18:15:10.990 回答
1

遇到了同样的问题。在构建项目的 jar 时偶尔会拾取一个非常大 (3GB) 的日志文件,这导致了问题。删除文件后没有错误,目标 jar 的大小回到 10Mb 以下。

于 2014-02-05T20:21:15.180 回答
0

正如我们在此处看到的 (ZipEntry class),这已在 JDK 1.7 中得到修复。

您已经证明mvn从命令行运行显示 JDK 版本 1.7。

您是否尝试以相同的方式完成构建,我的意思是从命令行(而不是 IDE,它可以为 maven 使用另一个 JDK?)

于 2013-10-02T12:09:54.003 回答
0

使用打包前shade未运行导致的插件时,我遇到了类似的问题(OP 中的相同错误) 。mvn clean

于 2016-12-29T17:33:40.170 回答