我们在构建中签署了很多jar文件。目前,它占总构建时间的60-80%,将其从15分钟更改为45分钟以上。因此,我们非常有兴趣通过并行化来加快签名过程。
所有jar都在一个文件夹中,现在我们的脚本看起来像这样:
<property name="jars.dir" location="......" />
<signJar ...paswords etc... />
<fileset dir="${jars.dir}" includes="**/*.jar" />
</signJar>
我不能轻易使用parallel
标签,因为所有的jar都在一个文件夹中,所以我们需要一些其他的方法来使它并行。构建将在许多不同的计算机和服务器上运行,因此解决方案足够灵活以处理不同数量的核心非常重要。
答案 0 :(得分:3)
您可以使用for task迭代jar文件集,然后通过调用signJar任务对每个jar进行签名。 for任务还有一个并行选项和用于控制并发的属性。
答案 1 :(得分:1)
FWIW,这是我用来为webstart签名和打包JAR的宏。这会添加所需的清单属性,并通过重新打包来规范化JAR以进行签名。
当从并行<for>
循环中调用时,此宏工作正常。
您需要使用密钥信息调整<signjar>
任务。
<!-- Macro for JAR signing and pack200 -->
<macrodef name="sign-and-pack">
<attribute name="jar"/>
<sequential>
<echo message="Signing and packing @{jar}..."/>
<!-- Kill any existing signatures and delete existing manifest -->
<exec executable="zip" logError="true" failonerror="false">
<arg value="-d"/>
<arg value="--quiet"/>
<arg value="@{jar}"/>
<arg value="META-INF/MANIFEST.MF"/>
<arg value="META-INF/*.SF"/>
<arg value="META-INF/*.DSA"/>
<arg value="META-INF/*.RSA"/>
</exec>
<!-- Rebuild manifest with the required attributes -->
<jar update="true" file="@{jar}">
<manifest>
<attribute name="Application-Name" value="${webstart.app.name}"/>
<attribute name="Permissions" value="all-permissions"/>
<attribute name="Codebase" value="*"/>
<attribute name="Trusted-Only" value="true"/>
</manifest>
</jar>
<!-- Pack and unpack JAR to normalize it -->
<exec executable="pack200" logError="true" failonerror="true">
<arg value="--quiet"/>
<arg value="--repack"/>
<arg value="@{jar}"/>
</exec>
<!-- Sign JAR -->
<signjar keystore="mykeystore.p12" storetype="pkcs12" storepass="secret123" jar="@{jar}"
alias="my key alias"/>
<!-- Compress JAR -->
<exec executable="pack200" logError="true" failonerror="true">
<arg value="--quiet"/>
<arg value="--modification-time=latest"/>
<arg value="@{jar}.pack.gz"/>
<arg value="@{jar}"/>
</exec>
</sequential>
</macrodef>