jfrog artifactory 使用
Artifactory 仓库类型
Artifactory 仓库主要有四种类型,远程仓库、本地仓库、虚拟仓库及分发仓库,分别应用在如下不同的场景。
远程仓库
Artifactory 仓库支持代理公网或内网二进制软件制品仓库(Artifactory, Nexus,Harbor等),按需获取后在本地进行缓存,可大幅度提升构建效率。于代理及缓存公共仓库,不能向此类型的仓库上传私有组件。
本地仓库
Artifactory 本地仓库用来存储本地构建产出的软件制品。本地仓库中的软件制品通常都带有丰富的元数据,并且通过基于角色的访问控制(RBAC)实现资源隔离。用于内部使用,上传的组件不会向外部进行同步。
虚拟仓库
为满足制品管理的多团队协作需求,虚拟仓库通过打包任意数量的远程仓库和本地仓库,暴露唯一的访问入口的方式,将制品提供者和消费者之间的耦合度降到最低,提升协作效率。
分发仓库
分发仓库通过JFrog Bintray SaaS服务满足软件制品公网分发的需求,提供默认的全球CDN加速服务。
修改base url

创建本地仓库
用于deploy自己的jar包
讯享网
选择创建本地库:

选择maven类型:

输入有意义的库名:

上传包:x-pack-sql-7.8.0.jar

注意: 如果提示你 jar 过大是因为 jfrog 默认最大只能上传 100m 的资源,可以去设置里进行更改,然后再重新上传。

查看:

访问一下包:

一般情况下,需要根据环境创建local库,这里创建两个:一样的建立方式, 一个release库, 一个snapshot库
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OVjGPqQU-24)(好好学习.assets/image-.png)]
两个本地库如下:

创建远程仓库

Select Package Type 选择 Maven;Repository Key 输入一个有意义的名字


配置一下basic即可:

默认的远程仓库是https://repo1.maven.org/maven2/
也可以改成阿里仓库地址的https://maven.aliyun.com/repository/public 等
然后点击右下角的Create Remote Repository即可
其中:https://repo1.maven.org/maven2/ ,test能成功
阿里仓库会test报错,不用去理会报错

阿里云Maven仓库
官方介绍: https://developer.aliyun.com/mvn/guide
阿里云Maven中央仓库为 阿里云云效 提供的公共代理仓库,帮助研发人员提高研发生产效率,使用阿里云Maven中央仓库作为下载源,速度更快更稳定。
阿里云云效 是企业级一站式 DevOps 平台,覆盖产品从需求到运营的研发全生命周期,其中云效也提供了免费、可靠的Maven私有仓库 Packages 和代码管理仓库 Codeup,欢迎您体验使用。
云效制品仓库 Packages 致力于帮助开发者统一管理各种开发语言在开发、构建过程中的依赖,构建成果(二进制制品)以及交付过程关键信息的重要组件。
云效代码管理 Codeup 是阿里云出品的一款企业级代码管理平台,提供代码托管、代码评审、代码扫描、代码度量等功能,不限人数、超大容量且免费使用,全方位保护代码资产,帮助团队实现安全、稳定、高效的研发管理。

阿里云maven 配置指南:
打开 maven 的配置文件( windows 机器一般在 maven 安装目录的 conf/settings.xml ),在标签中添加 mirror 子节点:

讯享网<mirror> <id>aliyunmaven</id> <mirrorOf>*</mirrorOf> <name>阿里云公共仓库</name> <url>https://maven.aliyun.com/repository/public</url> </mirror>
如果想使用其它代理仓库,可在节点中加入对应的仓库使用地址。以使用 spring 代理仓为例:
<repository> <id>spring</id> <url>https://maven.aliyun.com/repository/spring</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </repository>
在你的 pom.xml 文件节点中加入你要引用的文件信息:
讯享网<dependency> <groupId>[GROUP_ID]</groupId> <artifactId>[ARTIFACT_ID]</artifactId> <version>[VERSION]</version> </dependency>
执行拉取命令:
mvn install
创建虚拟仓库
创建好本地仓库和远程仓库,如果项目中要引用仓库的话需要同时依赖多个仓库,需要再创建一个虚拟仓库,统一管理本地和远程仓库,项目中只需要引用虚拟仓库即可。


这样设置之后我们开发的之后就直接设置maven的仓库地址为虚拟仓库fazi_virtual_repo,找不到的jar包会从远程仓库中找,同时我们发布的jar包会直接发布到artifactory的本地仓库libs-release-local中.
一般情况下,与local库一致,也是需要创建相应的两个virtual库:
一样的建立方式, 一个代理release, 一个代理snapshot, 注意排序和选择默认的deploy库, 这样在maven项目中deploy jar包时, jfrog才知道要部署要哪个库(否则就要在maven setting和distributionManagement中指定部署的私库)

同样的创建过程:注意不同的virtual库选择不同的local库


创建用户和组
用户:

组:


配置仓库权限
建议按组配置

这里配置仓库,不能选择virtual库,只能是远程库和本地库。

分配组:

项目中使用仓库
在以下页面找到仓库的地址

创建setting.xml:

简单的修改一下生成的setting.xml文件,修改用户名和密码之后就可以用生成的settign 文件覆盖maven的conf文件夹下面的设置文件.
注意增加本地库目录配置:
C:/Program Files/apache-maven-3.8.4/m22/repository
讯享网<?xml version="1.0" encoding="UTF-8"?> <settings xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.2.0 http://maven.apache.org/xsd/settings-1.2.0.xsd" xmlns="http://maven.apache.org/SETTINGS/1.2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <localRepository>C:/Program Files/apache-maven-3.8.4/m22/repository</localRepository> <servers> <server> <username>${security.getCurrentUsername()}</username> <password>${security.getEscapedEncryptedPassword()!"* Insert encrypted password here *"}</password> <id>central</id> </server> <server> <username>${security.getCurrentUsername()}</username> <password>${security.getEscapedEncryptedPassword()!"* Insert encrypted password here *"}</password> <id>snapshots</id> </server> </servers> <profiles> <profile> <repositories> <repository> <snapshots> <enabled>false</enabled> </snapshots> <id>central</id> <name>fazi_release_virtual</name> <url>http://lsyk04:8081/artifactory/fazi_release_virtual</url> </repository> <repository> <snapshots /> <id>snapshots</id> <name>fazi_snapshot_virtual</name> <url>http://lsyk04:8081/artifactory/fazi_snapshot_virtual</url> </repository> </repositories> <pluginRepositories> <pluginRepository> <snapshots> <enabled>false</enabled> </snapshots> <id>central</id> <name>fazi_release_virtual</name> <url>http://lsyk04:8081/artifactory/fazi_release_virtual</url> </pluginRepository> <pluginRepository> <snapshots /> <id>snapshots</id> <name>fazi_snapshot_virtual</name> <url>http://lsyk04:8081/artifactory/fazi_snapshot_virtual</url> </pluginRepository> </pluginRepositories> <id>artifactory</id> </profile> </profiles> <activeProfiles> <activeProfile>artifactory</activeProfile> </activeProfiles> </settings>
完成上述设置之后我们就可以找一个自己的maven工程,然后再工程目录下使用mvn clean package 我们就能发现mvn会从artifactory 服务器中拉取依赖。
上述的密码是加密的,在jfrog artifactory 里会加密成功:
- 在user 里可以

- 在set me up里生成后下载:

生成后点击下载:

pom文件设置
打开上面步骤中使用过得Set Me Up 界面,选择Deploy ,我们只需要在自己的项目pom文件中加入下面的设置之后,我们就可以直接使用mvn deploy 想打包好的jar文件发布到artifactory的本地仓库中

在项目的 pom.xml 文件添加如下配置
<distributionManagement> <repository> <id>central</id> <name>lsyk04-releases</name> <url>http://lsyk04:8081/artifactory/fazi_release_virtual</url> </repository> <snapshotRepository> <id>snapshots</id> <name>lsyk04-snapshots</name> <url>http://lsyk04:8081/artifactory/fazi_snapshot_virtual</url> </snapshotRepository> </distributionManagement> 以上经过了测试,id要和setting里的id一致 以下没有测试 <repositories> <repository> <id>jfrog</id> <name>jfrog</name> <!-- 注意:这里是 jfrog 服务上的仓库地址 --> <url>http://lsyk04:8081/artifactory/fazi_release_virtual/</url> <!-- Release版本则代表稳定的版本 --> <releases> <enabled>true</enabled> </releases> <!-- Snapshot版本代表不稳定、尚处于开发中的版本,默认关闭,需要手动启动 --> <snapshots> <enabled>true</enabled> </snapshots> </repository> </repositories> <!-- 指定插件仓库 --> <pluginRepositories> <pluginRepository> <id>jfrog</id> <name>jfrog</name> <url>http://lsyk04:8081/artifactory/fazi_release_virtual//</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </pluginRepository> </pluginRepositories>




版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/119811.html