1. 在 https://issues.sonatype.org/secure/Signup!default.jspa (其实类似于本地仓库nexus,只是在上传maven公共仓库,需要经过这个第三方组织的公共仓库)注册账号,如果已有,则跳过该步;
2. 如果创建 groupId ,则需要新建一个工单(Issues),点击导航最上面的Create按钮,然后会弹出下面的对话框,将Project=Community Support和Issue Type=new project,然后根据Java包的功能分别写上Summary、Description、Group Id、SCM url以及Project URL、Usernames等必要信息,创建完之后需要等待Sonatype的工作人员审核处理,审核时间还是很快的,我的审核差不多等待了半个小时。当Issue的Status变为RESOLVED后,同时会收到邮件,此时就可以进行下一步操作了。
注意:
项目类型是 Community Support - Open Source Project Repository Hosting
groupId 对应的域名,你需要有所有权
如果是在已有的 groupId 中提交更新,要么创建人在创建issue时添加你的用户名进去到他的issue中。要么自己创建issue,按上面步骤,并且说明清楚。
3. 使用gpg生成密钥对
1)如果使用的是Windows,可以到https://www.gpg4win.org/download.html下载gpg4win,推荐使用 Gpg4win-Vanilla 2.3.3版本
2)如果使用的是Linux,可以通过yum install gpg命令安装gpg。
linux下: gpg --gen-key
windows下: gpg –-gen-key
4. 检查已生成的密钥列表
gpg --list-keys
第一行是公钥文件路径,第二行是公钥信息,第三行是用户ID,第四行是私钥信息。
5. 将公钥发布到 PGP 密钥服务器
gpg --keyserver hkp://pool.sks-keyservers.net --send-keys B15C5AA3
B15C5AA3 是公钥信息
6. 查询公钥是否发布成功
gpg --keyserver hkp://pool.sks-keyservers.net --recv-keys B15C5AA3
7. 修改Maven配置文件
需要修改全局的setting.xml和项目的pom.xml文件。
setting.xml
找到maven的全局配置文件settings.xml,在里面找到 节点,这个节点默认是注释掉的,增加如下配置:
sonatype-nexus-snapshots
Sonatype网站的账号
Sonatype网站的密码
sonatype-nexus-releases
Sonatype网站的账号
Sonatype网站的密码
上面的username和password就是你在步骤一注册的帐号和密码。
pom.xml
org.sonatype.oss
oss-parent
7
并增加Licenses、SCM、Developers信息等,在此不贴源码了。
sonatype-nexus-snapshots
https://oss.sonatype.org/content/repositories/snapshots
sonatype-nexus-releases
https://oss.sonatype.org/service/local/staging/deploy/maven2
此处,snapshotRepository 与 repository 中的 id 一定要与 setting.xml 中 server 的 id 保持一致。
8. 部署和发布Jar包
在源码目录下,使用命令方式执行:
mvn clean deploy -P sonatype-oss-release
执行以上 Maven 命令时,会提示需要输入上面提到的 Passphase,它就是刚才设置的 GPG 密钥库的密码
上述命令执行后,Jar包将会发布到sonatype的构件仓库中,可以到 https://oss.sonatype.org/#stagingRepositories 查看发布好的Jar
9. 在 OSS 中,使用自己的 Sonatype 账号登录后,可在 Staging Repositories 中查看刚才已上传的构件,这些构件目前是放在 Staging 仓库中,可进行模糊查询,快速定位到自己的构件。此时,该构件的状态为 Open,然后依次点击上方的Close–>Confirm,在弹出的对话框中输入Jar包的描述信息,这个信息将会在Maven搜索结果当作简介介绍Jar包的,所以建议输的详细点。当状态变成closed后,执行Release–>Confirm,同样会弹出一个类似于上面的对话框,还是输入那些介绍信息即可,当这步执行完之后,构件将会自动删除。
10. 通知 Sonatype 构件已成功发布
在第2步中创建的Issue下面回复一条“The component has been successfully released”的评论,即通知 Sonatype 的工作人员为需要发布的构件做审批,发布后会关闭该Issue。
11. 等待构件审批通过
审批通过后,将会收到邮件通知。
12. 从中央仓库中搜索构件
大概2小时后,可以在Maven中央仓库搜索到
网友评论