在github上托管Maven存储库

emm*_*mby 305 github maven github-pages mvn-repo

我有一个小型开源库的分支,我正在github上工作.我想通过maven将其提供给其他开发人员,但我不想运行自己的Nexus服务器,因为它是一个分支,我不能轻易地将它部署到oss.sonatype.org.

我想要做的是将它部署到github,以便其他人可以使用maven访问它.最好的方法是什么?

emm*_*mby 471

我能找到的最佳解决方案包括以下步骤:

  1. 创建一个名为mvn-repo托管maven工件的分支.
  2. 使用github site-maven-plugin将你的工件推送到github.
  3. 配置maven以将您的远程数据库mvn-repo用作maven存储库.

使用此方法有几个好处:

  • Maven工件在一个单独的分支中保持与源分开mvn-repo,就像github页面被保存在一个单独的分支中一样gh-pages(如果你使用github页面)
  • 与其他一些提议的解决方案不同,gh-pages如果您使用它们,它不会与您的解决方案冲突.
  • 与部署目标自然匹配,因此没有新的maven命令可供学习.只要mvn deploy像往常一样使用

将工件部署到远程maven仓库的典型方法是使用mvn deploy,所以让我们修补此解决方案的机制.

首先,告诉maven将工件部署到目标目录中的临时临时位置.将此添加到您的pom.xml:

<distributionManagement>
    <repository>
        <id>internal.repo</id>
        <name>Temporary Staging Repository</name>
        <url>file://${project.build.directory}/mvn-repo</url>
    </repository>
</distributionManagement>

<plugins>
    <plugin>
        <artifactId>maven-deploy-plugin</artifactId>
        <version>2.8.1</version>
        <configuration>
            <altDeploymentRepository>internal.repo::default::file://${project.build.directory}/mvn-repo</altDeploymentRepository>
        </configuration>
    </plugin>
</plugins>
Run Code Online (Sandbox Code Playgroud)

现在尝试跑步mvn clean deploy.您将看到它将您的maven存储库部署到target/mvn-repo.下一步是让它将该目录上传到GitHub.

添加您的身份验证信息,~/.m2/settings.xml以便github site-maven-plugin可以推送到GitHub:

<!-- NOTE: MAKE SURE THAT settings.xml IS NOT WORLD READABLE! -->
<settings>
  <servers>
    <server>
      <id>github</id>
      <username>YOUR-USERNAME</username>
      <password>YOUR-PASSWORD</password>
    </server>
  </servers>
</settings>
Run Code Online (Sandbox Code Playgroud)

(如上所述,请chmod 700 settings.xml确保没有人可以在文件中读取您的密码.如果有人知道如何使用site-maven-plugin提示输入密码而不是在配置文件中要求,请告诉我.)

然后site-maven-plugin通过将以下内容添加到您的pom中,告诉GitHub 您刚刚配置的新服务器:

<properties>
    <!-- github server corresponds to entry in ~/.m2/settings.xml -->
    <github.global.server>github</github.global.server>
</properties>
Run Code Online (Sandbox Code Playgroud)

最后,配置site-maven-plugin从临时staging repo上传到mvn-repoGithub 上的分支:

<build>
    <plugins>
        <plugin>
            <groupId>com.github.github</groupId>
            <artifactId>site-maven-plugin</artifactId>
            <version>0.11</version>
            <configuration>
                <message>Maven artifacts for ${project.version}</message>  <!-- git commit message -->
                <noJekyll>true</noJekyll>                                  <!-- disable webpage processing -->
                <outputDirectory>${project.build.directory}/mvn-repo</outputDirectory> <!-- matches distribution management repository url above -->
                <branch>refs/heads/mvn-repo</branch>                       <!-- remote branch name -->
                <includes><include>**/*</include></includes>
                <repositoryName>YOUR-REPOSITORY-NAME</repositoryName>      <!-- github repo name -->
                <repositoryOwner>YOUR-GITHUB-USERNAME</repositoryOwner>    <!-- github username  -->
            </configuration>
            <executions>
              <!-- run site-maven-plugin's 'site' target as part of the build's normal 'deploy' phase -->
              <execution>
                <goals>
                  <goal>site</goal>
                </goals>
                <phase>deploy</phase>
              </execution>
            </executions>
        </plugin>
    </plugins>
</build>
Run Code Online (Sandbox Code Playgroud)

mvn-repo分支,不需要存在,它会为你创建.

现在又跑mvn clean deploy了.您应该看到maven-deploy-plugin将文件"上传"到目标目录中的本地staging存储库,然后site-maven-plugin提交这些文件并将它们推送到服务器.

[INFO] Scanning for projects...
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building DaoCore 1.3-SNAPSHOT
[INFO] ------------------------------------------------------------------------
...
[INFO] --- maven-deploy-plugin:2.5:deploy (default-deploy) @ greendao ---
Uploaded: file:///Users/mike/Projects/greendao-emmby/DaoCore/target/mvn-repo/com/greendao-orm/greendao/1.3-SNAPSHOT/greendao-1.3-20121223.182256-3.jar (77 KB at 2936.9 KB/sec)
Uploaded: file:///Users/mike/Projects/greendao-emmby/DaoCore/target/mvn-repo/com/greendao-orm/greendao/1.3-SNAPSHOT/greendao-1.3-20121223.182256-3.pom (3 KB at 1402.3 KB/sec)
Uploaded: file:///Users/mike/Projects/greendao-emmby/DaoCore/target/mvn-repo/com/greendao-orm/greendao/1.3-SNAPSHOT/maven-metadata.xml (768 B at 150.0 KB/sec)
Uploaded: file:///Users/mike/Projects/greendao-emmby/DaoCore/target/mvn-repo/com/greendao-orm/greendao/maven-metadata.xml (282 B at 91.8 KB/sec)
[INFO] 
[INFO] --- site-maven-plugin:0.7:site (default) @ greendao ---
[INFO] Creating 24 blobs
[INFO] Creating tree with 25 blob entries
[INFO] Creating commit with SHA-1: 0b8444e487a8acf9caabe7ec18a4e9cff4964809
[INFO] Updating reference refs/heads/mvn-repo from ab7afb9a228bf33d9e04db39d178f96a7a225593 to 0b8444e487a8acf9caabe7ec18a4e9cff4964809
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 8.595s
[INFO] Finished at: Sun Dec 23 11:23:03 MST 2012
[INFO] Final Memory: 9M/81M
[INFO] ------------------------------------------------------------------------
Run Code Online (Sandbox Code Playgroud)

在浏览器中访问github.com,选择mvn-repo分支,并验证所有二进制文件现在都在那里.

在此输入图像描述

恭喜!

您现在可以通过运行将您的maven工件部署到穷人的公共仓库mvn clean deploy.

您还需要采取一个步骤,即配置依赖于您的pom的任何pom,以了解您的存储库的位置.将以下代码段添加到依赖于项目的任何项目的pom中:

<repositories>
    <repository>
        <id>YOUR-PROJECT-NAME-mvn-repo</id>
        <url>https://raw.github.com/YOUR-USERNAME/YOUR-PROJECT-NAME/mvn-repo/</url>
        <snapshots>
            <enabled>true</enabled>
            <updatePolicy>always</updatePolicy>
        </snapshots>
    </repository>
</repositories>
Run Code Online (Sandbox Code Playgroud)

现在任何需要jar文件的项目都会自动从你的github maven存储库下载它们.

编辑:避免注释中提到的问题('创建提交错误:无效请求.对于'属性/名称',nil不是字符串.'),请确保在github上的配置文件中声明了一个名称.

  • 另请注意,此解决方案将在每次部署时覆盖以前的工件.这适用于快照存储库,但不适用于已发布的工件.要禁用该行为,请在site-maven-plugin配置中设置"<merge> true </ merge>".但是,如果你这样做,我认为你必须在github中手动创建mvn-repo分支并在第一次删除它的所有文件. (25认同)
  • 为了使这个工作适用于**多模块项目**,你也可以简单地使用`<altDeploymentRepository> internal.repo :: default :: file:// $ {user.dir}/target/mvn-repo </altDeploymentRepository>`with*maven-deploy-plugin*,``outputDirectory> $ {user.dir}/target/mvn-repo </ outputDirectory>`with*site-maven-plugin*.这会将所有工件部署到根("父")项目中,并将它们推送到github上的相应父目录.否则,每个子模块的构建将覆盖之前构建的子模块的构建... (17认同)
  • +1聪明,很好地呈现.我唯一的批评是你没有包含Maven插件网站的链接:https://github.com/github/maven-plugins.我正在寻找一种方法将我的Maven网站发布到github! (13认同)
  • 在github上使用双因素身份验证时,此方法不起作用.请参阅此处的问题:https://github.com/github/maven-plugins/issues/36#issuecomment-31005606 (7认同)
  • 两个使它工作的建议(至少对我而言):设置当前版本的Github插件(现在它将是0.11).另外我建议大家使用OAUTH令牌而不是密码.您可以在"设置 - >应用程序 - >个人访问令牌"中生成它.您也可以将其内联到POM中并将令牌存储为环境变量.`````<github.global.userName> YourUserName </github.global.userName> <github.global.password> $ {GITHUB_OAUTH_TOKEN </github.global.password>```` (7认同)
  • (请注意,托管maven工件的首选方法是仍然使用nexus服务器.但是,当现有服务器或托管您自己的服务器不是一个简单的选项时,使用github可以作为轻量级替代方案.另外,请注意,您不会能够直接浏览你的maven资源库.Github不允许你在使用raw时浏览目录结构.但是,你总是可以通过访问你的github页面并浏览`mvn-repo`分支来浏览repo.) (2认同)

Bae*_*Bae 118

不要将GitHub用作Maven资源库.

编辑:此选项获得了大量的投票,但没有评论为什么.无论在GitHub上实际托管的技术能力如何,这都是正确的选择.由于下面列出的所有原因而在GitHub上托管是错误的,如果没有评论,我无法改进答案以澄清您的问题.

最佳选择 - 与原始项目协作

最好的选择是说服原始项目包含您的更改并坚持使用原始项目.

替代方案 - 维护自己的叉子

由于您已经分叉了一个开源库,并且您的fork也是开源的,因此您可以将您的fork上传到Maven Central(阅读将工件上载到中央存储库的指南),为其提供一个新的groupId,也许是一个新的artifactId.

如果您愿意维护此分支,直到将更改合并到原始项目中,然后您应该放弃这个选项,则只考虑此选项.

真的很难认为叉子是否是正确的选择.阅读无数谷歌搜索结果'为什么不分叉'

推理

使用jar扩展您的存储库会增加下载大小,无益

jar是output你的项目之一,它可以随时从它重新生成inputs,你的GitHub repo应该只包含inputs.

不相信我?然后检查Google搜索结果"不要在git中存储二进制文件".

GitHub的帮助处理大文件会告诉你同样的事情.不可否认,jar并不大,但它们比源代码更大,一旦发布了jar,他们就没有理由进行版本控制 - 这就是新版本的用途.

在pom.xml中定义多个repos可以减少存储库数量减去工件数量

斯蒂芬康诺利:

如果有人添加你的repo他们会影响他们的构建性能,因为他们现在有另一个repo来检查工件...如果你只需要添加一个repo,这不是一个大问题......但问题在增长,接下来你知道你的maven build正在检查每个工件的50个回购,并且构建时间是一只狗.

那就对了!Maven需要针对您定义的每个存储库检查pom.xml中定义的每个工件(及其依赖关系),因为任何这些存储库中都可以使用较新的版本.

为自己尝试一下,你会感受到缓慢构建的痛苦.

文物的最佳位置是Maven Central,因为它是罐子的中心位置,这意味着你的构建只会检查一个地方.

您可以在Maven的存储库简介文档中阅读有关存储库的更多信息

  • 我怀疑Github有问题,因为他们编写了启用此功能的插件.我同意这不是一个想法,但是我很高兴. (5认同)
  • 在Sonatype上部署开源项目并不总是可行的.例如,当您的项目依赖于另一个尚未部署的开源项目时(并且由于它不符合sonatype要求而无法部署). (4认同)
  • 完全同意,并且对于您想要保留一段时间的叉子有意义.但是,对于现有项目的一个小补丁来说,这可能是一个很大的开销. (3认同)

And*_*ejs 45

您可以使用JitPack(免费用于公共Git存储库)将您的GitHub存储库公开为Maven工件.它很容易.您的用户需要将其添加到他们的pom.xml:

  1. 添加存储库:
<repository>
    <id>jitpack.io</id>
    <url>https://jitpack.io</url>
</repository>
Run Code Online (Sandbox Code Playgroud)
  1. 添加依赖:
<dependency>
    <groupId>com.github.User</groupId>
    <artifactId>Repo name</artifactId>
    <version>Release tag</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)

正如其他地方所解释的那样,JitPack将构建您的GitHub仓库,并将为罐子服务.要求是您有一个构建文件和一个GitHub版本.

好消息是您不必处理部署和上传.由于您不想维护自己的工件库,因此可以很好地满足您的需求.


Rus*_*pez 16

自 2019 年以来,您现在可以使用名为Github 包注册表的新功能。

基本上流程是:

  • 从 github 设置生成一个新的个人访问令牌
  • 在您的中添加存储库和令牌信息 settings.xml
  • 部署使用

    mvn deploy -Dregistry=https://maven.pkg.github.com/yourusername -Dtoken=yor_token  
    
    Run Code Online (Sandbox Code Playgroud)

  • “Github Package Registry”对于开源项目来说毫无用处,因为客户端无法在未经授权的情况下下载工件。 (5认同)
  • 很奇怪......你创建了你的公共包,但其他人在获取它之前需要身份验证 (3认同)
  • 但对于其他人使用它,他/她似乎需要使用相应的 URL 和身份验证信息配置 settings.xml (2认同)

Jil*_*urp 9

另一种方法是使用webdav支持的任何web托管.当然,你需要一些空间,但设置起来很简单,是运行完整的nexus服务器的好选择.

将此添加到您的构建部分

     <extensions>
        <extension>
        <artifactId>wagon-webdav-jackrabbit</artifactId>
        <groupId>org.apache.maven.wagon</groupId>
        <version>2.2</version>
        </extension>
    </extensions>
Run Code Online (Sandbox Code Playgroud)

将这样的内容添加到您的distributionManagement部分

<repository>
    <id>release.repo</id>
    <url>dav:http://repo.jillesvangurp.com/releases/</url>
</repository>
Run Code Online (Sandbox Code Playgroud)

最后确保在settings.xml中设置存储库访问权限

将此添加到您的服务器部分

    <server>
        <id>release.repo</id>
        <username>xxxx</username>
        <password>xxxx</password>
    </server>
Run Code Online (Sandbox Code Playgroud)

以及您的存储库部分的定义

            <repository>
                <id>release.repo</id>
                <url>http://repo.jillesvangurp.com/releases</url>
                <releases>
                    <enabled>true</enabled>
                </releases>
                <snapshots>
                    <enabled>false</enabled>
                </snapshots>
            </repository>
Run Code Online (Sandbox Code Playgroud)

最后,如果您有任何标准的PHP托管,您可以使用sabredav之类的东西来添加webdav功能.

优点:您拥有自己的maven存储库缺点:您在nexus中没有任何管理功能; 你需要在某处设置一些webdav


Gui*_*ume 8

作为替代方案,Bintray提供免费托管maven存储库.如果你绝对不想重命名groupId,这可能是Sonatype OSS和Maven Central的一个很好的替代品.但请,至少要努力将您的更改集成到上游或重命名并发布到Central.它使其他人更容易使用你的分叉.

  • 它不再是免费的.每月150美元. (6认同)
  • 我尝试时无法相信,但Bintray不支持快照.无用. (3认同)