- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我们使用 Jenkins,它使用 md5 指纹来识别 Artifact 以及 Artifact 自上次构建以来是否发生了变化。不幸的是,Maven 构建总是生成二进制不同的 Artifact 。
因此,我正在考虑让 Maven 为同一组输入文件生成相同的 jar Artifact ,而不管它们是在何时何地构建的,这意味着 jar 文件中的条目必须排序 - 不仅在索引,但按照它们写入 jar 文件的顺序。
在检查了使用maven-assembly-plugin的maven-jar-plugin后,我的结论是他们不会在一次写入之前将所有要写入的文件收集到内存中,而是一次写入一个。这意味着对生成的 jar 进行后处理而不是更改当前行为可能更好,这样我当时可以对条目进行排序、将时间戳归零等。
我不熟悉编写 Maven 插件,所以我的问题是,我应该如何编写一个 Maven 知道如何判断 artifact-jar-in-progress 所在位置以及如何将其连接到我的 pom.xml 中的插件?
(起初我需要它来处理 jar 文件,但 war 文件也不错)。
最佳答案
如前所述,这可以基于类似于 maven-shade-plugin
的东西来完成。我继续编写了一个简单的插件来添加此功能——参见 https://github.com/manouti/jar-timestamp-normalize-maven-plugin (在 Central repo 上可用)。
该行为基于 shade
插件。它包含一个名为 normalize
的目标,可以绑定(bind)到 package
生命周期阶段并在项目的 POM 中配置:
<plugins>
<plugin>
<groupId>com.github.manouti</groupId>
<artifactId>jar-timestamp-normalize-maven-plugin</artifactId>
<version>1.0-SNAPSHOT</version>
<executions>
<execution>
<id>jar-normalize</id>
<goals>
<goal>normalize</goal>
</goals>
<phase>package</phase>
</execution>
</executions>
</plugin>
</plugins>
关于插件的几点说明:
正在构建的 Artifact 通过 project#getArtifact()
访问,其中 project
是一个 org.apache.maven.project.MavenProject
.
归一化主要包括三个步骤:
将所有 Jar 条目的最后修改时间设置为特定时间戳(默认值为 1970-01-01 00:00:00AM
但可以通过 -Dtimestamp 更改
系统属性)。
list 中属性的重新排序(按字母顺序),但始终排在第一位的 Manifest-Version
除外。
从 pom.properties
文件中删除注释,其中包含导致 Jar 因构建而异的时间戳。
调用后,目标将在原始 Artifact 旁边生成输出文件(名为 artifactId-version-normalized.jar
),即在 project.build.directory
目录。
关于java - 在组装之后但在安装之前对 jar 进行后处理(以获得幂等构建),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24961072/
我在编写数学函数时遇到了麻烦。它应该接受 3 个变量并像这样计算方程。 答案 = x(1 + y/100)^ z 我把它写成: public compute_cert (int years, doub
我正在开发一个计算器,以便更好地学习 Java。我编写了自己的代码来使用 BigDecimal 参数计算幂。截至目前,代码无法处理分数幂,例如 2^2.2。为了解决这个问题,我想在我的代码中实现指数恒
我正在寻找一种算法(或者更好的是,代码!)来生成幂,特别是奇数指数大于 1 的数字:三次幂、五次幂、七次幂等等。然后我想要的输出是 8, 27, 32, 125, 128, 216, 243, 343
在 Codewars 上找到这个。该函数接受两个参数 A 和 B,并返回 A^B 的最后一位。下面的代码通过了前两个测试用例,但不会通过下一个测试用例。 def last_digit(n1, n2):
像 2^(2%1) 这样的表达式在 GHCi 中不会进行类型检查,并且错误消息是神秘的。为什么这不起作用,我需要改变什么? 我无法转换为其他类型,我希望将其用于 27^(1%3) 等表达式。 最佳答案
我的二次幂没有达到应有的水平,所以我想也许我可以 #define 做点什么。 不幸的是,我在预处理器指令方面经验不足,我不知道如何做 for 循环之类的事情。我看了看: http://www.cplu
如何在 Math.net 中获得三角函数的幂? Expr x = Expr.Variable("x"); Expr g = (2 * x).Sinh().Pow(2); g.ToString()给出输
我正在尝试拟合这个渐近接近零(但从未达到它)的数据。 我相信最好的曲线是逆逻辑函数,但欢迎建议。关键是预期的衰减“S 曲线”形状。 这是我到目前为止的代码,以及下面的绘图图像,这是一个非常丑陋的适合。
这个问题在这里已经有了答案: The most efficient way to implement an integer based power function pow(int, int) (2
我试图获得指数非常大的 double 值的幂(Java BigInteger 可以包含它(指数),例如:10^30 ) 也就是说,我想找到类似 1.75^(10^30) 或 1.23^(3423453
我有一个数学表达式,例如: ((2-x+3)^2+(x-5+7)^10)^0.5 我需要更换 ^符号到pow C语言的功能。我认为正则表达式是我需要的,但我不知道像专业人士那样的正则表达式。所以我最终
这是我的 previous question on bit flags 的后续内容,我澄清了一些重大误解。 我需要创建这些函数来查找包含零个或多个标志的 int 中的单个位标志: BitBinaryU
我已经在 java 中为 BigInteger 尝试过 modPow() 函数。 但它需要太长时间。 我知道模乘法,甚至也知道求幂。 但由于条件限制,我无法解决这个问题。 a、b 的值可以包含 100
我是一名优秀的程序员,十分优秀!