jfrog artifactory 的使用

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-1658780314824)(好好学习.assets/image-20220726041401393.png)]

两个本地库如下:

在这里插入图片描述

创建远程仓库

在这里插入图片描述

Select Package Type 选择 MavenRepository 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 里会加密成功:

  1. 在user 里可以

    在这里插入图片描述

  2. 在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>

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值