使用 Maven/Hudson/Mercurial 进行发布
Posted
技术标签:
【中文标题】使用 Maven/Hudson/Mercurial 进行发布【英文标题】:Doing Releases with Maven/Hudson/Mercurial 【发布时间】:2012-01-24 16:26:02 【问题描述】:我正在尝试通过 Maven 发布插件进行发布,但 SCM 配置存在问题。我正在使用安装了 m2eclipse 的 Eclipse。我们使用 Mercurial,在我的机器(Win7)上安装了 TortoiseHg。我有一个创建 jar 的测试项目。我们为我们的项目使用了一个超级 pom,所以测试项目 pom 也是如此。我已经在超级 pom 中设置了这个:
<build>
<plugins>
....
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-scm-plugin
<version>1.6</version>
<configuration>
<connectionType>connection</connectionType>
</configuration>
</plugin>
</plugins>
</build>
我的测试项目 pom 如下所示:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>my.group</groupId>
<artifactId>TestJar
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>my.group</groupId>
<artifactId>super-pom</artifactId>
<version>1.0</version>
</parent>
<scm>
<connection>
scm:hg:ssh://our.scm.server:22//path/to/TestJarProject
</connection>
<developerConnection>
scm:hg:ssh://our.scm.server:22//path/to/TestJarProject
</developerConnection>
</scm>
</project>
请注意,我们通过 ssh 连接到我们的 SCM 服务器。我怀疑我遇到的一些问题与此有关。我只能找到使用 http 的示例。
在我的 settings.xml 文件中,我添加了这个:
<servers>
...
<server>
<id>our.scm.server</id>
<username>username</username>
<password>password</password>
</server>
</servers>
当我运行 release:prepare release:perform 时,会弹出一个 TortoisePlink 对话框,提示我输入密码。对话框询问“@our.scm.server 的密码”。
它似乎没有使用 settings.xml 文件中的用户名或密码,这是我通过向其中添加服务器元素所期望的。应该是吗?我也尝试将我的用户名添加到连接 url:
<connection>
scm:hg:ssh://username@our.scm.server:22//path/to/TestJarProject
</connection>
但仍提示输入空的用户名密码。
问题一
有没有人在进行 Maven 发布时成功使用 ssh 连接到 Mercurial?
由于我最终想在 Hudson 中进行构建,因此我设置了一个 Hudson 作业来进行发布,但它失败并出现以下错误:
[INFO] o.h.m.e.h.MavenExecutionResultHandler - Build failed with exception(s)
[INFO] o.h.m.e.h.MavenExecutionResultHandler - [1] org.apache.maven.lifecycle.\
LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:\
maven-release-plugin:2.0:prepare (default-cli) on project TestJar: Cannot \
prepare the release because you have local modifications :
[.maven/repo/ca/shaw/eng/nms/nms-super-pom/1.0/_maven.repositories:unknown]
[.maven/repo/ca/shaw/eng/nms/nms-super-pom/1.0/nms-super-pom-1.0.pom:unknown]
[.maven/repo/ca/shaw/eng/nms/nms-super-pom/1.0/nms-super-pom-1.0.pom.sha1:unknown]
... many, many more lines of this nature .....
问题二
Maven 遇到了哪些本地修改?
由于项目是从 repo 中提取的,我能想到的唯一更改是更新 pom 文件(从版本中删除 SNAPSHOT)。但是 Maven 不应该抱怨这一点,因为它自己做出了改变,不是吗?
更新
根据 khmarbaise 的建议,我已将此添加到我的父 POM:
<pluginManagement>
<plugins>
<plugin>
<artifactId>maven-release-plugin</artifactId>
<version>2.2.2</version>
</plugin>
</plugins>
</pluginManagement>
【问题讨论】:
首先在你的父母中做一个 pluginManagement 部分并配置一个新版本的 maven-release-plugin 因为你使用的是 2.0,它有点过时了......你使用哪个 Maven 版本?哈德森是最新的吗?使用 Hudson 的发布插件? 我们使用的是 Hudson 2.1.2 和 Maven 3(与 Hudson 捆绑) 您是否先检查过是否可以在没有 Hudson 的情况下在命令行上进行发布? (添加了 pluginManagement 部分?) 在我本地的 Win7 机器上,是的,我尝试使用mvn -B release:prepare release:perform
进行命令行发布。 TortoisePlink 密码对话框在字符串中显示了我的用户名两次 它提示我输入我的密码 (usernam@our.scm.server's password
),然后再次提示我输入密码 (@our.scm.server's password
),它不能接受 (没有用户名)在我取消构建之前,我处于无限循环中。
【参考方案1】:
问题一
有没有人在进行 Maven 发布时成功使用 ssh 连接到 Mercurial?
答案似乎是 Maven 发布插件仅适用于 https。通常按照此页面上的说明,我们能够让 https 在我们的 Mercurial 服务器上运行:
https://www.mercurial-scm.org/wiki/HgWebDirStepByStep
问题二
Maven 遇到了哪些本地修改?
本地修改是在构建期间创建的.maven
目录。通过将.maven/*
添加到我的.hgignore
文件中,我能够完成构建。
【讨论】:
【参考方案2】:我现在无法重现这一点,但根据之前的经验,我记得 ssh 连接仅适用于基于密钥的身份验证,而不适用于用户名和密码。这不一定特定于发布插件和/或其 Mercurial 支持。
编辑:我今天尝试使用 Mercurial 和发布插件版本 2.4.1 进行基于密钥的 ssh 访问,并且效果很好。一种可能的问题来源是 SCM URL 格式。在我的情况下是:
scm:hg:ssh://user@hostname.com/path
所以你的问题一的答案是:是的,但不是用户名/密码身份验证。我没有遇到任何“本地修改”问题,但我的 .hgignore 中有目标,所以可能就是这样。
【讨论】:
以上是关于使用 Maven/Hudson/Mercurial 进行发布的主要内容,如果未能解决你的问题,请参考以下文章
在使用加载数据流步骤的猪中,使用(使用 PigStorage)和不使用它有啥区别?
Qt静态编译时使用OpenSSL有三种方式(不使用,动态使用,静态使用,默认是动态使用)