溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

maven中如何使用OSSRH中心倉庫

發(fā)布時(shí)間:2021-08-05 16:46:49 來源:億速云 閱讀:173 作者:Leah 欄目:編程語言

今天就跟大家聊聊有關(guān)maven中如何使用OSSRH中心倉庫,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

為什么使用中心倉庫

這個(gè)中心倉庫是Apache Maven, SBT 默認(rèn)的repository。同時(shí)還可以支持 Apache Ant/Ivy, Gradle 等構(gòu)建工具的使用。

現(xiàn)在的軟件界是開源的軟件界,越來越多的人和企業(yè)愿意在網(wǎng)絡(luò)上貢獻(xiàn)自己的代碼,于是有了maven社區(qū)的中心倉庫,可以方便任何人共享和使用jar包。

發(fā)布到中心倉庫前的準(zhǔn)備工作

發(fā)布到中心倉庫是需要權(quán)限的,我們需要注冊我們的項(xiàng)目也就是artifacts id,并且指定需要將項(xiàng)目發(fā)布到哪里。

Sonatype 提供了一個(gè)叫做開源軟件資源庫托管Open Source Software Repository Hosting (OSSRH) 的工具,幫助我們來方便的將項(xiàng)目發(fā)布到中心倉庫中。它是項(xiàng)目所有者和貢獻(xiàn)者將其組件發(fā)布到中央資源庫的主要途徑。

我們需要選擇一個(gè)你所擁有的domain作為groupId,對于GitHub groupId(io.github.username),只要您的項(xiàng)目URL與所請求的groupId匹配,就會立即進(jìn)行驗(yàn)證。

對于其他的域名,可以通過下面兩種方式之一來進(jìn)行域名的驗(yàn)證:

  1. 使用TXT文件驗(yàn)證:在域名下創(chuàng)建一個(gè)代表OSSRH ticket number的TXT文件來進(jìn)行驗(yàn)證。

  2. GitHub重定向:設(shè)置你的域名到托管項(xiàng)目的GitHub URL的重定向。

使用OSSRH

Sonatype OSSRH(OSS存儲庫托管)使用Sonatype Nexus存儲庫管理器為開源項(xiàng)目二進(jìn)制文件提供存儲庫托管服務(wù)。 OSSRH使用的是Maven存儲庫格式,我們可以部署開發(fā)版本的二進(jìn)制文件snapshots,階段發(fā)布二進(jìn)制文件,還可以升級二進(jìn)制文件并將其同步到中央倉庫中。

使用Sonatype創(chuàng)建ticket

Sonatype使用JIRA來管理創(chuàng)建請求,所以我們需要首先創(chuàng)建一個(gè)JIRA賬號,創(chuàng)建賬號地址: https://issues.sonatype.org/secure/Signup!default.jspa , 然后使用該賬戶創(chuàng)建一個(gè)Project ticket,創(chuàng)建ticket地址:https://issues.sonatype.org/secure/CreateIssue.jspa?issuetype=21&pid=10134。

一般來說會在2個(gè)工作日內(nèi)進(jìn)行審核。

中央倉庫中的組件要求

不同于我們自己的私人倉庫,中央倉庫中的組件的格式是有一定要求的。我們需要遵循它的格式規(guī)范。

提供Javadoc 和源代碼

除了pom文件之外,還需要提供javadoc文件和源代碼文件。這樣的目的是方便在IDE中直接訪問使用。

這些文件的命名遵循Maven存儲庫格式的命名約定,使用artifactId加上version作為文件名稱,并根據(jù)類型使用javadoc或者sources作為名字的區(qū)分,以jar結(jié)尾,比如:

<groupId>com.example.applications</groupId>
<artifactId>example-application</artifactId>
<version>1.4.7</version>

其對應(yīng)的javadoc文件和源代碼文件如下:

example-application-1.4.7-sources.jar
example-application-1.4.7-javadoc.jar

如果確實(shí)沒有javadoc和源代碼文件,比如Scala項(xiàng)目,那么需要創(chuàng)建一個(gè)假的文件來通過驗(yàn)證。

使用GPG/PGP給文件簽名

所有的文件都需要使用GPG/PGP進(jìn)行簽名,生成一個(gè).asc后綴的文件,比如對應(yīng)下面的文件:

example-application-1.4.7.pom
example-application-1.4.7.jar
example-application-1.4.7-sources.jar
example-application-1.4.7-javadoc.jar

需要生成:

example-application-1.4.7.pom.asc
example-application-1.4.7.jar.asc
example-application-1.4.7-sources.jar.asc
example-application-1.4.7-javadoc.jar.asc

Metadata文件

Metadata文件也就是需要提交的pom文件。 這是Apache Maven用來定義項(xiàng)目及其構(gòu)建的Project Object Model文件。 使用其他工具進(jìn)行構(gòu)建時(shí),必須對其進(jìn)行組裝并確保其包含下面幾項(xiàng)必須的信息。

除了必需的信息外,還建議包含項(xiàng)目的正確依賴關(guān)系,以便構(gòu)建工具可以使用該信息正確地解決傳遞依賴關(guān)系,并且不需要用戶手動管理依賴關(guān)系。

  1. 項(xiàng)目坐標(biāo)信息,也叫做GAV。包括groupId ,artifactId和version,如下所示:

<groupId>com.example.applications</groupId>
<artifactId>example-application</artifactId>
<version>1.4.7</version>

除此之外,如果項(xiàng)目不是jar包,還需要包含packaging信息,有效的值包括: jar , war ,ear , pom , maven-plugin , ejb , rar , par , aar 和 apklib 。

  1. 項(xiàng)目名字,描述和URL信息:

<name>Example Application</name>
<description>A application used as an example on how to set up pushing 
  its components to the Central Repository.</description>
<url>http://www.example.com/example-application</url>

還可以使用變量來構(gòu)建項(xiàng)目名:

<name>{project.groupId}:{project.artifactId}</name>
  1. License信息

<licenses>
  <license>
    <name>The Apache License, Version 2.0</name>
    <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
  </license>
</licenses>
  1. 開發(fā)者信息

<developers>
    <developer>
      <name>Manfred Moser</name>
      <email>manfred@sonatype.com</email>
      <organization>Sonatype</organization>
      <organizationUrl>http://www.sonatype.com</organizationUrl>
    </developer>
  </developers>
  1. SCM信息

SCM是你項(xiàng)目的地址,如果使用的svn可以這樣寫:

<scm>
  <connection>scm:svn:http://subversion.example.com/svn/project/trunk/</connection>
  <developerConnection>scm:svn:https://subversion.example.com/svn/project/trunk/</developerConnection>
  <url>http://subversion.example.com/svn/project/trunk/</url>
</scm>

如果使用的github可以這樣寫:

<scm>
  <connection>scm:git:git://github.com/simpligility/ossrh-demo.git</connection>
  <developerConnection>scm:git:ssh://github.com:simpligility/ossrh-demo.git</developerConnection>
  <url>http://github.com/simpligility/ossrh-demo/tree/master</url>
</scm>

部署

部署的目的是將生成的組件部署到本地的倉庫中,有很多工具可以使用,最常見的就是Apache Maven,其他的構(gòu)建工具比如Apache ant、Gradle、sbt等都可以很方便的構(gòu)建項(xiàng)目。

注意,OSSRH單個(gè)文件有上傳大小限制,最大為1024MB。如果需要上傳更大的組件,需要聯(lián)系sonatype。

上傳到中央倉庫

本地部署好之后,就可以上傳到中央倉庫了。

可以使用Nexus Staging Maven Plugin 或者 Ant Tasks 來通過命令行上傳。也可以直接瀏覽器訪問 https://oss.sonatype.org/ 來上傳。

一旦發(fā)布,組件會在10分鐘之內(nèi)發(fā)布到中央倉庫,并且在2個(gè)小時(shí)之內(nèi),可以從中央倉庫搜索到。

我們以瀏覽器發(fā)布為例來看一下具體的步驟。

首先使用JIRA創(chuàng)建的用戶名和密碼登錄到 https://oss.sonatype.org/ 。

maven中如何使用OSSRH中心倉庫

登錄之后,在左下角可以看到Build Promotion選項(xiàng),我們選擇Staging Repositories ,就會展示目前處于stage狀態(tài)的倉庫。

在部署過程中創(chuàng)建的stage存儲庫會有一個(gè)名稱,該名稱以項(xiàng)目的groupId開頭(刪除其中的點(diǎn)),帶有破折號和4位數(shù)字。 例如。 如果您的項(xiàng)目groupId為com.example.applications,則staging配置文件名稱將以comexampleapplications開頭。 序列號從1000開始,并且隨著部署的增加而增加,比如:comexampleapplication-1010。

選擇staging存儲庫,列表下方的面板將顯示有關(guān)存儲庫的更多詳細(xì)信息。 另外,可以點(diǎn)擊CloseRelease按鈕。

看完上述內(nèi)容,你們對maven中如何使用OSSRH中心倉庫有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI