GitLab-CI中的artifacts和cache 的区别

在GitLab-CI中, cacheartifacts比较容易混淆.

其中 cache 指的是缓存, 常用于依赖安装中, 如几个jobs都需要安装相同的依赖, 可以使用依赖, 此时可以加快依赖的安装进度;
对于artifacts则是将某个工件上传到GitLab提供下载或后续操作使用, 由于每个job启动时, 都会自动删除.gitignore中指定的文件, 因此对于依赖安装目录, 即可以使用cache, 也可以使用artifacts.

两个主要有以下几个区别:

  1. cache不一定命中,artifacts肯定命中, 能否使用cache取决当当前机器是否生成过cache, artifacts则每次都会从GitLab下载
  2. 重新安装时因为使用的是缓存, 所以很有可能不是最新的
  3. 特别是开发环境, 如果每次都希望使用最新的更新, 应当删除cache, 使用artifacts, 这样可以保证确定的更新
    4.artifacts中定义的部分, 会自动生成, 并可以传到下面的job中解压使用, 避免了重复依赖安装等工作
  4. 如果使用Docker运行Gitlab-Runner, cache会生成一些临时容器, 不容易清理
  5. artifacts可以设置自动过期时间, 过期自动删除,cache不会自动清理
  6. artifacts会先传到GitLab服务器, 然后需要时再重新下载, 所以这部分也可以在GitLab下载和浏览

artifacts 的依赖使用

下面是一个使用artifacts的例子, 首先有一个安装依赖的工作, 然后工作完成后, 会将安装文件转移到后续的工作时

installing-dependencies:
    stage: prepare
    script:
        - composer install --prefer-dist --optimize-autoloader -n --no-interaction -v --no-suggest
        - composer dump-autoload --optimize
    artifacts:
        name: "vendor"
        untracked: true
        expire_in: 60 mins
        paths:
            - $CI_PROJECT_DIR/vendor    
code-review:
    stage: testing
    dependencies:
        - installing-dependencies
    script:
        - php vendor/bin/phpcs --config-set ignore_warnings_on_exit 1
        - php vendor/bin/phpcs --standard=PSR2 -w --colors ./
test-image:
    stage: build
    image: docker:latest
    services:
        - docker:dind
    dependencies:
        - installing-dependencies
    script:        
        - docker build -t $CI_PROJECT_NAME:latest .
        - docker push domain.com/repos/$CI_PROJECT_NAME:latest
    only:
        - develop

使用cache

cache:
    paths:
        - vendor
before_scritp:    
    - composer install --prefer-dist --optimize-autoloader -n --no-interaction -v --no-suggest
    - composer dump-autoload --optimize    
code-review:
    stage: testing    
    script:
        - php vendor/bin/phpcs --config-set ignore_warnings_on_exit 1
        - php vendor/bin/phpcs --standard=PSR2 -w --colors ./
test-image:
    stage: build
    image: docker:latest
    services:
        - docker:dind    
    script:        
        - docker build -t $CI_PROJECT_NAME:latest .
        - docker push domain.com/repos/$CI_PROJECT_NAME:latest
    only:
        - develop

禁用artifacts

默认artifacts会自动在不同的stage中传输, 如果该stage中的job不需要artifacts, 则可以禁用artifacts, 以加速构建速度

dependencies: []

注意

使用cache会出现一个问题, 就是缓存有可能使用上次执行该job时的缓存, 不能保证某些文件最新

### .gitlab-ci.yml 关键字详解 #### 1. 配置文件概述 `.gitlab-ci.yml` 是 GitLab CI/CD 中的核心配置文件,用于定义项目的构建、测试部署流程。它基于 YAML 格式编写,因此需要注意缩进规则以及语法准确性。 #### 2. 常见关键字及其作用 ##### (1) `stages` `stages` 定义了流水线的不同阶段顺序,这些阶段决定了作业的执行次序。每个作业都必须属于某个特定的阶段。 ```yaml stages: - build - test - deploy ``` 上述例子表明流水线分为三个阶段:build、test deploy[^1]。 ##### (2) `job` `job` 表示具体的任务单元,在 `.gitlab-ci.yml` 文件中通常以独立的部分表示。每一个 job 至少需要指定一个 stage 属性来决定其所属阶段。 ```yaml my_job: stage: test script: - echo "Running my job" ``` 此部分展示了名为 `my_job` 的 task 将会在 `test` 阶段被执行,并打印一条消息到控制台[^2]。 ##### (3) `script` `script` 字段指定了实际运行的一系列命令或者脚本。这是最基础也是最重要的字段之一。 ```yaml rspec: script: - bundle install - rake db:create RAILS_ENV=test - rails spec ``` 这里展示了一个典型的 Ruby 测试环境设置过程[^4]。 ##### (4) `artifacts` 当某些 jobs 结束后可能希望保存一些产物供后续使用或下载查看时可以利用 artifact 功能。例如生成的日志文件或者其他二进制数据等都可以作为 artifacts 被保留下来。 ```yaml build_artifact: ... artifacts: paths: - public/ expire_in: '1 week' ``` 上面的例子设置了路径下的所有内容会被打包成压缩包并存储一周时间[^3]。 ##### (5) `cache` 为了加速重复性的操作比如依赖安装可以通过缓存机制实现减少冗余计算量的目的。 ```yaml caching_example: cache: key: "$CI_COMMIT_REF_SLUG" paths: - vendor/ruby script: - gem install bundler && bundle install --path=vendor/ruby ``` 这段代码片段说明如果存在相同的分支名称则会尝试加载已存在的 gems 缓存从而加快第二次及以后的构建速度。 ##### (6) 特殊字符处理(针对 Windows) 由于操作系统差异,在 windows 平台上运行 yaml 脚本时需注意特殊变量符号 `$` 应改为 `%` 来适应 cmd 解析器的要求。 ```yaml windows_specific_job: artifacts: name: "%CI_JOB_STAGE%_%CI_COMMIT_REF_NAME%" untracked: true ``` 此处演示了如何修改默认行为使得能够在 windows 下正常工作。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值