Maven发布Release到中心仓库历程记录(无个人域名)

前言

因为前段时间自己做了一个爬虫项目(地址),自己很希望分享到maven中心仓库上,感觉拥有自己的jar包令我兴奋,便开始了maven发布的探索之路,在 这个过程中,遇到了不少的问题,本文把整个过程记录下来,希望以后能够帮助到有需要的人

准备工作

  • 注册maven发布的账号

    注册地址:注册,注册过程中最好能保存一下密码,不然真的很容易忘记,注册过程我就不多说了,把用户名,密码填写完就行了

  • 创建一个发布项目的issue

    创建地址:创建

    创建的注意事项:

  • 下载安装GPG并生成密钥

    下载地址:下载

    下载时候注意一下,它会让你捐赠的,如果你不想捐赠,可以选择捐赠0,然后点击下载,安装时候,一路点击下一步就行了,注意第一步就会让你选择语言,最好选简体中午,如果你英语8级,当我没说

    生成密钥

    生成密钥有两种方式:命令行和GPG界面生成

    1.命令行:

    1. 生成:
    2. gpg --gen-key
    3. Real name: 名字(E文)(我填了fanyong)
    4. Email address: 邮箱(自己的邮箱,我的是1023079644@qq.com)
    5. You selected this USER-ID:
    6. "xxx[xxx@qq.com](mailto:xxx@qq.com)"
    7. Change (N)ame, (E)mail, or (O)kay/(Q)uit? o
    8. 之后往下,会让你输入用户名和邮箱,还有一个Passphase(输入两次,我的是fanyong920),相当于密钥库密码,不要忘记。
    1. 查看公钥
    2. gpg --list-keys
    3. 查询结果:
    4. C:/Users/fanyong/AppData/Roaming/gnupg/pubring.kbx
    5. --------------------------------------------------
    6. pub rsa2048 2020-06-06 [SC] [expires: 2022-06-06]
    7. 85B594371E0A38D70243B1E927EDC1D952E45892
    8. uid [ultimate] fanyong <1023079644@qq.com>
    9. sub rsa2048 2020-06-06 [E] [expires: 2022-06-06]
    1. 其中85B594371E0A38D70243B1E927EDC1D952E45892就是你的公钥的指纹
    1. 发布公钥:
    2. gpg --keyserver hkp://keyserver.ubuntu.com:11371 --send-keys 85B594371E0A38D70243B1E927EDC1D952E45892
    1. 查询发布公钥是否成功
    2. gpg --keyserver hkp://keyserver.ubuntu.com:11371 --recv-keys 85B594371E0A38D70243B1E927EDC1D952E45892
    3. 成功的话会有如下结果
    4. gpg: key 27EDC1D952E45891: "fanyong <1023079644@qq.com>" not changed
    5. gpg: Total number processed: 1
    6. gpg: unchanged: 1

    2.操作界面

    ​ 第一步

    ​ 第二步:

    填写密钥密码,我的是fanyong920,这一步我借用了别人的截图,所以图片上填的不是fanyong920

    第三步:公钥上传至服务器

    如果上传服务器失败,则试着更改一下服务器地址:

    设置(S)->配置Kleopatra(C),修改 OpenPGP密钥服务器。

    可选的服务器地址:

    在你上传过程中,如果密钥不存在服务器,那么就会有错误提示信息,里面的服务器地址就是可选的

    到这里准备工作就已经做好了

    按照issue一步一步往下走

    如果你是上午提的issue,估计很快就会得到了回复,因为老外在线,如果你是下午的话,有可能要到半夜才能回你了

    1.如果issue得到了回复,那么应该是如下这样:

    2.issue的第二次得到回复

    因为我的项目是放在github上,并且用了io.github.fanyong920的域名作为groupId,所以对方要验证fanyong920是不是我的账号

    3.issue的第三次得到回复

接下来就是最重要的步骤了:上传jar包到release,snapshot仓库

我只是发布了release版本,所以下面步骤以上传jar到release仓库为例:

  • Maven的settins文件设置

    1.在servers中添加

    1. <server>
    2. <id>sonatype-nexus-snapshots</id>
    3. <username>https://issues.sonatype.org的账号</username>
    4. <password>https://issues.sonatype.org的密码</password>
    5. </server>
    6. <server>
    7. <id>sonatype-nexus-staging</id>
    8. <username>https://issues.sonatype.org的账号</username>
    9. <password>https://issues.sonatype.org的密码</password>
    10. </server>
    11. <server>
    12. <id>ossrh</id>
    13. <username>https://issues.sonatype.org的账号</username>
    14. <password>https://issues.sonatype.org的密码</password>
    15. </server>

    2.在mirrors中配置了阿里云仓库,已经配置的可以跳过

    1. <mirror>
    2. <id>alimaven</id>
    3. <name>aliyun maven</name>
    4. <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
    5. <mirrorOf>central</mirrorOf>
    6. </mirror>

    3.在profiles中配置

    1. <profile>
    2. <id>ossrh</id>
    3. <activation>
    4. <activeByDefault>true</activeByDefault>
    5. </activation>
    6. <properties>
    7. <gpg.executable>C:/Program Files (x86)/GnuPG/bin/gpg.exe</gpg.executable>
    8. <gpg.passphrase>上面生成的密钥密码:fanyong920</gpg.passphrase>
    9. <gpg.homedir>{找到dir:cmd->gpg --list-key}C:/Users/fanyong/AppData/Roaming/gnupg</gpg.homedir>
    10. </properties>
    11. </profile>
  • POM.xml文件设置

    1.配置必须的标签:url,developers,licenses,scm,distributionManagement

  1. <url>https://github.com/fanyong920/jvppeteer</url>
  2. <developers>
  3. <developer>
  4. <id>fanyong</id>
  5. <name>fanyong</name>
  6. <email>1023079644@qq.com</email>
  7. <roles>
  8. <role>Project Manager</role>
  9. <role>Architect</role>
  10. </roles>
  11. <timezone>+8</timezone>
  12. </developer>
  13. </developers>
  14. <licenses>
  15. <license>
  16. <name>Apache License</name>
  17. <url>https://github.com/fanyong920/jvppeteer/blob/master/LICENSE</url>
  18. </license>
  19. </licenses>
  20. <scm>
  21. <url>https://github.com/fanyong920/jvppeteer</url>
  22. <connection>https://github.com/fanyong920/jvppeteer.git</connection>
  23. </scm>
  24. <distributionManagement>
  25. <snapshotRepository>
  26. <id>ossrh</id>
  27. <url>https://oss.sonatype.org/content/repositories/snapshots</url>
  28. </snapshotRepository>
  29. <repository>
  30. <id>ossrh</id>
  31. <url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
  32. </repository>
  33. </distributionManagement>

2.配置发布的maven插件

里面有个配置:com.ruiyun改成你对应的包结构

  1. <build>
  2. <!-- configured plugins -->
  3. <pluginManagement>
  4. <plugins>
  5. <plugin>
  6. <groupId>biz.aQute.bnd</groupId>
  7. <artifactId>bnd-maven-plugin</artifactId>
  8. <version>4.3.1</version>
  9. <executions>
  10. <execution>
  11. <goals>
  12. <goal>bnd-process</goal>
  13. </goals>
  14. <!-- com.ruiyun改成你对应的包结构 -->
  15. <configuration>
  16. <bnd><![CDATA[
  17. Export-Package: \
  18. com.ruiyun.*
  19. -noextraheaders: true
  20. -snapshot: SNAPSHOT
  21. ]]></bnd>
  22. </configuration>
  23. </execution>
  24. </executions>
  25. </plugin>
  26. <plugin>
  27. <groupId>org.apache.maven.plugins</groupId>
  28. <artifactId>maven-compiler-plugin</artifactId>
  29. <version>3.7.0</version>
  30. <configuration>
  31. <source>1.8</source>
  32. <target>1.8</target>
  33. </configuration>
  34. </plugin>
  35. <plugin>
  36. <groupId>org.apache.maven.plugins</groupId>
  37. <artifactId>maven-gpg-plugin</artifactId>
  38. <version>1.6</version>
  39. <executions>
  40. <execution>
  41. <id>sign-artifacts</id>
  42. <phase>verify</phase>
  43. <goals>
  44. <goal>sign</goal>
  45. </goals>
  46. </execution>
  47. </executions>
  48. </plugin>
  49. <plugin>
  50. <groupId>org.apache.maven.plugins</groupId>
  51. <artifactId>maven-jar-plugin</artifactId>
  52. <version>3.0.2</version>
  53. <configuration>
  54. <archive>
  55. <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
  56. </archive>
  57. </configuration>
  58. </plugin>
  59. <plugin>
  60. <groupId>org.apache.maven.plugins</groupId>
  61. <artifactId>maven-javadoc-plugin</artifactId>
  62. <version>2.10.3</version>
  63. <configuration>
  64. <encoding>UTF-8</encoding>
  65. <aggregate>true</aggregate>
  66. <charset>UTF-8</charset>
  67. <docencoding>UTF-8</docencoding>
  68. </configuration>
  69. <executions>
  70. <execution>
  71. <id>attach-javadocs</id>
  72. <goals>
  73. <goal>jar</goal>
  74. </goals>
  75. </execution>
  76. </executions>
  77. </plugin>
  78. <plugin>
  79. <groupId>org.apache.maven.plugins</groupId>
  80. <artifactId>maven-shade-plugin</artifactId>
  81. <version>3.1.0</version>
  82. </plugin>
  83. <plugin>
  84. <groupId>org.apache.maven.plugins</groupId>
  85. <artifactId>maven-source-plugin</artifactId>
  86. <version>3.0.0</version>
  87. <executions>
  88. <execution>
  89. <id>attach-sources</id>
  90. <goals>
  91. <goal>jar-no-fork</goal>
  92. </goals>
  93. </execution>
  94. </executions>
  95. </plugin>
  96. <plugin>
  97. <groupId>org.sonatype.plugins</groupId>
  98. <artifactId>nexus-staging-maven-plugin</artifactId>
  99. <version>1.6.8</version>
  100. </plugin>
  101. </plugins>
  102. </pluginManagement>
  103. <sourceDirectory>src/main/java</sourceDirectory>
  104. <testSourceDirectory>src/test/java</testSourceDirectory>
  105. <plugins>
  106. <plugin>
  107. <groupId>biz.aQute.bnd</groupId>
  108. <artifactId>bnd-maven-plugin</artifactId>
  109. </plugin>
  110. <plugin>
  111. <groupId>org.apache.maven.plugins</groupId>
  112. <artifactId>maven-compiler-plugin</artifactId>
  113. </plugin>
  114. </plugins>
  115. </build>
  116. <profiles>
  117. <profile>
  118. <id>ossrh</id>
  119. <activation>
  120. <property>
  121. <name>performRelease</name>
  122. <value>true</value>
  123. </property>
  124. </activation>
  125. <build>
  126. <plugins>
  127. <plugin>
  128. <groupId>biz.aQute.bnd</groupId>
  129. <artifactId>bnd-maven-plugin</artifactId>
  130. </plugin>
  131. <plugin>
  132. <groupId>org.apache.maven.plugins</groupId>
  133. <artifactId>maven-gpg-plugin</artifactId>
  134. </plugin>
  135. <plugin>
  136. <groupId>org.sonatype.plugins</groupId>
  137. <artifactId>nexus-staging-maven-plugin</artifactId>
  138. <extensions>true</extensions>
  139. <configuration>
  140. <serverId>ossrh</serverId>
  141. <nexusUrl>https://oss.sonatype.org/</nexusUrl>
  142. <autoReleaseAfterClose>true</autoReleaseAfterClose>
  143. </configuration>
  144. </plugin>
  145. <plugin>
  146. <groupId>org.apache.maven.plugins</groupId>
  147. <artifactId>maven-source-plugin</artifactId>
  148. </plugin>
  149. <plugin>
  150. <groupId>org.apache.maven.plugins</groupId>
  151. <artifactId>maven-javadoc-plugin</artifactId>
  152. </plugin>
  153. </plugins>
  154. </build>
  155. </profile>
  156. </profiles>
  • 执行发布命令

    1. mvn clean deploy -P ossrh
    2. 这里的ossrh是对应profileid

    顺利的话,这个命令会BUILD SUCCESS

发布成功后,你还需要在iusse上回复对方,你已经发布了release版本到maven中心了

一般在这时候,两个小时左右,你的jar包就同步到了maven中心。

在未同步之前,你可以到https://search.maven.org 查看你的jar包的具体信息

我的搜索出来就是这个样子:

我的爬虫框架的坐标是:

  1. <dependency>
  2. <groupId>io.github.fanyong920</groupId>
  3. <artifactId>jvppeteer</artifactId>
  4. <version>1.0.1</version>
  5. </dependency>

如何发布快照版本?

在pom.xml中的项目版本号后面加上 -SNAPSHOT 就行

不需要执行关闭、发布构建步骤,(对应nexus-staging-maven-plugin的autoReleaseAfterClose)快照版发布后就可以直接引用了

Maven发布Release到中心仓库历程记录(无个人域名)的更多相关文章

  1. Maven发布封装到中央仓库时候报错:no default secret key: No secret key

    今天因为发布swagger-spring-boot-starter做一个问题的修复,然后碰到了下面这个问题,记录一下解决过程,帮助后续碰到类似问题的童鞋: *gpg: WARNING: "- ...

  2. 如何发布代码到maven中心仓库

    deploy to sonatype 参考文章 https://blog.csdn.net/xuefu_78/article/details/52494698 https://blog.csdn.ne ...

  3. maven中心仓库OSSRH使用简介

    目录 简介 为什么使用中心仓库 发布到中心仓库前的准备工作 使用OSSRH 使用Sonatype创建ticket 中央仓库中的组件要求 提供Javadoc 和源代码 使用GPG/PGP给文件签名 Me ...

  4. maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

    maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository. ...

  5. Maven中心仓库

    当你使用Maven构建一个项目,Maven会检查你的pom.xml文件,找出需要下载的依赖包.首先它会到本地仓库查找所需的文件,如果没找到,就到默认的中心仓库(这是新的http://search.ma ...

  6. Maven学习总结(三):修改从Maven中心仓库下载到本地的jar包的默认存储位置

    一:修改从Maven中心仓库下载到本地的jar包的默认存储位置 从Maven中心仓库下载到本地的jar包的默认存放在”${user.home}/.m2/repository”中,${user.home ...

  7. maven 发布到本地仓库

    1.maven打包命令 maven package命令只是将你需要打包的项目打包到项目的class文件夹下面,并没有发布到本地仓库或者私服上面,现在多模块开发的打包一般依赖私服或者 本地仓库,因此,我 ...

  8. 修改从Maven中心仓库下载到本地的jar包的默认存储位置及远程仓库

    从Maven中心仓库下载到本地的jar包的默认存放在”${user.home}/.m2/repository”中,${user.home}表示当前登录系统的用户目录(如"C:\Users\g ...

  9. Maven私服Nexus3.x环境构建操作记录

    Maven介绍Apache Maven是一个创新的软件项目管理和综合工具.Maven提供了一个基于项目对象模型(POM)文件的新概念来管理项目的构建,可以从一个中心资料片管理项目构建,报告和文件.Ma ...

随机推荐

  1. python re 里面match 和search的区别

    re.match()从开头开始匹配string. re.search()从anywhere 来匹配string. 例子: >>> re.match("c", &q ...

  2. webpack指南(四)shimming

    shimming 将一个新的 API 引入到一个旧的环境中,而且仅靠旧的环境中已有的手段实现. ProvidePlugin 我们在程序中暴露一个变量,通知webpack某个库被使用,webpack将在 ...

  3. vue上的简单轮播图

    好久没写轮播图了,今天在vue上写了个超简单的,效果还ok. .moveLeft{position:relative;right:ZOOMpx;transition:all 1s;} 原理是滚动时利用 ...

  4. 2-SAT poj3207将边看做点

    Ikki's Story IV - Panda's Trick Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 10238 ...

  5. SICP 题解集合

    1.1(略) 1.2 biwascheme> (/ (+ 5 4 (- 2 (- 3 (+ 6 (/ 4 5))))) (* 3 (- 6 2) (- 2 7))) => -0.24666 ...

  6. 3D视觉基础(基本原理及3D传感器基本参数)

    本人所在行业属于3D视觉方向,因此最近也是学习了很多3D视觉的知识,这次专门总结一下. 传统工业机器视觉中,2D指的是X方向加Y方向,那么3D视觉自然就是加了一个Z方向.目前我接触到的公司产品是3D激 ...

  7. Flink kuduSink开发

    1.继承RichSinkFunction (1)首先在构造方式传入kudu的masterAddress地址.默认表名.TableSerializationSchema.KuduTableRowConv ...

  8. sql语句中的删除操作

    drop: drop table tb; 删除内容和定义,释放空间.简单来说就是把整个表去掉.以后不能再新增数据,除非新增一个表. truncate: truncate table tb; 删除内容. ...

  9. 发光加载环动画-纯CSS动画效果-如何创建CSS3旋转预加载器(参照https://www.bilibili.com/video/BV1V4411C7z5?from=search&seid=9741275927942612817)

    //css部分 body{ margin:; padding:; background: #262626; } .ring{ position: absolute; top:50%; left: 50 ...

  10. dsPIC33EP单片机的PPS(外设引脚选择)

    利用dsPIC33EP单片机进行can通信的时候用到引脚复用 引脚复用通过查询数据手册: C1RX的寄存器为RPINR26.C1RXR=(设置为需要用到的引脚) 引脚设置为输入(C1RX),TRIS= ...