listmodule找不到现有的模块



我们在我们的内部网内可访问的nginx web服务器上有我们共享的Ivy存储库。我配置了一个url解析器来读取共享存储库,一个ssh解析器来写入共享存储库,主要是遵循Jason Grimes关于管理非java项目中的依赖关系的优秀博客文章。

现在我刚刚通过ssh解析器成功地将模块发布到存储库。在我的SFTP客户端中,我可以看到目录结构和位于web服务器服务目录中的文件:

com.organization/modulename/ivy-modulename-2.0.1.xml.md5
com.organization/modulename/ivy-modulename-2.0.1.xml.sha1
com.organization/modulename/ivy-modulename-2.0.1.xml
com.organization/modulename/modulename-2.0.1.zip.md5
com.organization/modulename/modulename-2.0.1.zip.sha1
com.organization/modulename/modulename-2.0.1.zip

然而,当我执行ivy:listmodule时,它似乎没有找到它。坦率地说,除了ivysettings初始化输出,它没有输出任何东西。

这是我正在执行的Ant目标:

<!-- ================================
     target: check-already-in-repo
     Check if the current version of a module already exists in the (shared) repository.
     ================================ -->
<target name="check-already-in-repo">
    <ivy:listmodules resolver="shared" organisation="${ivy.organisation}" module="${ivy.module}" revision="${version}" property="already-in-repo" value="true"/>
    <ac:if>
        <isset property="already-in-repo"/>
        <then>
            <echo>${ivy.module} ${version} already exists in the repository.</echo>
            <echo>Skipping publishing of ${ivy.module}.</echo>
        </then>
    </ac:if>
</target>

这是唯一的输出:

$ ant check-already-in-repo -Dversion=2.0.1 -Divy.organisation=com.organization -Divy.module=modulename
Buildfile: [...]/build.xml
check-already-in-repo:
[ivy:listmodules] :: Apache Ivy 2.4.0-rc1 - 20140315220245 :: http://ant.apache.org/ivy/ ::
[ivy:listmodules] :: loading settings :: file = [...]/build/ivysettings.xml
BUILD SUCCESSFUL
Total time: 0 seconds

我检查了ivy.shared.default.root的值和相应的常春藤和工件模式,它们都是匹配的(我保持它们简单)。

我用glob匹配器尝试了它,并使用organization=*, module=*revision=*调用ivy:listmodules,所以它应该在每种情况下返回一些。它没有。

我错过了什么?

下面是相关配置的其余部分:

<ivysettings>
    <!-- This file is referenced from multiple projects - DO NOT EDIT! -->
    <!-- shared -->
    <property name="ivy.shared.default.root" value="http://10.79.1.30/ivy"/>
    <property name="ivy.shared.default.ivy.pattern" value="[organisation]/[module]/ivy-[module]-[revision].[ext]"/>
    <property name="ivy.shared.default.artifact.pattern" value="[organisation]/[module]/[artifact]-[revision].[ext]"/>
    <!-- local -->
    <property name="ivy.local.default.root" value="${ivy.default.ivy.user.dir}/local"/>
    <property name="ivy.local.default.ivy.pattern" value="${ivy.shared.default.ivy.pattern}"/>
    <property name="ivy.local.default.artifact.pattern" value="${ivy.shared.default.artifact.pattern}"/>
    <settings defaultResolver="default"/>
    <resolvers>
        <filesystem name="local">
            <ivy pattern="${ivy.local.default.root}/${ivy.local.default.ivy.pattern}" />
            <artifact pattern="${ivy.local.default.root}/${ivy.local.default.artifact.pattern}" />
        </filesystem>
        <!-- read access -->
        <url name="shared">
            <ivy pattern="${ivy.shared.default.root}/${ivy.shared.default.ivy.pattern}" />
            <artifact pattern="${ivy.shared.default.root}/${ivy.shared.default.artifact.pattern}" />
        </url>
        <!-- write access -->
        <ssh name="ssh" host="10.79.1.30" port="22" user="ivy" userPassword="${ivy.ssh.password}" publishPermissions="0664">
            <ivy pattern="${ivy.shared.default.ivy.pattern}" />
            <artifact pattern="${ivy.shared.default.artifact.pattern}" />
        </ssh>
        <chain name="default" returnFirst="true">
            <resolver ref="local"/>
            <resolver ref="shared"/>
        </chain>
    </resolvers>
</ivysettings>

在使用-d(调试)选项执行Ant目标后,一些东西引起了我的注意:

$ ant check-already-in-repo -Dversion=2.0.1 -Divy.organisation=com.organization -Divy.module=modulename -d
[...]
[ivy:listmodules]   using shared to list all in http://10.79.1.30/ivy/
[ivy:listmodules] HTTP response status: 403 url=http://10.79.1.30/ivy/
[ivy:listmodules] CLIENT ERROR: Forbidden url=http://10.79.1.30/ivy/
[ivy:listmodules] HTTP response status: 403 url=http://10.79.1.30/ivy/
[ivy:listmodules] CLIENT ERROR: Forbidden url=http://10.79.1.30/ivy/
[ivy:listmodules] problem while listing resources in http://10.79.1.30/ivy/ with shared (java.io.IOException: The HTTP response code for http://10.79.1.30/ivy/ did not indicate a success. See log for more detail.)
[ivy:listmodules] java.io.IOException: The HTTP response code for http://10.79.1.30/ivy/ did not indicate a success. See log for more detail.
[...]

似乎listmodules工作,web服务器需要有目录列表启用。事实上,在添加

之后
location /ivy {
    autoindex on;
}

到nginx配置并重新启动web服务器,它最终工作如预期!

$ ant check-already-in-repo -Dversion=2.0.1 -Divy.organisation=com.organization -Divy.module=modulename
Buildfile: [...]/build.xml
check-already-in-repo:
[ivy:listmodules] :: Apache Ivy 2.4.0-rc1 - 20140315220245 :: http://ant.apache.org/ivy/ ::
[ivy:listmodules] :: loading settings :: file = [...]/build/ivysettings.xml
     [echo] modulename 2.0.1 already exists in the repository.
     [echo] Skipping publishing of modulename.
BUILD SUCCESSFUL
Total time: 0 seconds

万岁!: -)

相关内容

  • 没有找到相关文章

最新更新