0

我有一个在 GitLab Pages 上托管的原生 JavaScript 应用程序。最近,我一直在进行更改和错误修复,这些更改和错误修复已经破坏了该网站,直到已经推送了这些更改,我才注意到。

为了减少用户接触错误,我想在不同的文件夹中发布两个站点:

  • public/:master分支; 官方网站
  • public/staging/:staging分支; 夜间建筑

我希望这些对应于两个不同的分支:masterstaging

阅读GitLab CI for GitLab Pages,听起来这甚至是不可能的。我希望我读错了。

default:
  image: node:latest

test:
  stage: test
  script:
  - npm install
  - node test.js
  only:
  - staging
  - master

staging:
  stage: deploy
  environment: staging
  script:
  - mkdir -p public/staging
  - cp -r www public/staging
  artifacts:
    paths:
    - public
  only:
  - staging

pages:
  stage: deploy
  environment: production
  script:
  - mkdir -p public
  - cp -r www public
  artifacts:
    paths:
    - public
  only:
  - master

这可能吗?是否可以从两个不同的分支部署两个不同的文件夹?

4

2 回答 2

1

有趣的是,可以从任何分支机构发布,而不是从任何工作。

为此,我需要进行两项更改:

  1. 我需要知道已发布数据的当前状态
  2. 我需要根据当前分支更改目录

GitLab 具有缓存文件夹的能力。通常,这用于通过缓存下载的驱动程序来加速构建。没有理由我不能用它来存储public文件夹。这样,当我对 进行更改时staging,我会记住root应用程序的状态:

cache:
  paths:
  - public

下一个技巧是将页面发布到适当的文件夹,具体取决于正在构建的当前分支。为此,我们可以查看GitLab CI/CD 环境变量;尤其是:

  • CI_COMMIT_REF_SLUG: 当前分支
  • CI_DEFAULT_BRANCH:默认分支(主)

知道了这两个值,我们可以做一些事情bash来确定写入内容的正确位置。

pages:
  stage: deploy
  script:
  - dir="$CI_COMMIT_REF_SLUG"
  - if [ "$CI_COMMIT_REF_SLUG" == "$CI_DEFAULT_BRANCH" ]; then dir=""; fi;
  - dir="public/$dir"
  - echo "Deploying to $dir"
  - mkdir -p $dir
  - cp -r www $dir
  artifacts:
    paths:
    - public
  only:
  - staging
  - master

不要忘记将页面限制为仅stagingmaster

警告

我对此并不满意。

我认为最好将缓存维护在完全不同的地方并在稍后阶段将它们复制进去,但每次都完全重写公用文件夹。

当前的解决方案会随着时间的推移而变得笨拙,但基本思想是合理的。

于 2019-11-25T20:41:28.000 回答
1

正如您所描述的,您只能通过您的主分支发布对 GitLab 页面的更改。不过,GitLab 页面所做的唯一事情是将文件放在public名为pages. 这些文件可以是您想要的任何文件,只要您设法通过 GitLab 作业将它们放入此文件夹即可。

你可以尝试这样的事情:

pages:
  ...
  script:
    - mkdir -p public
    - cp -r www public
    - git checkout origin/staging
    - mkdir -p public/staging
    - cp -r www public/staging

我还没有测试过,所以如果它不起作用,请告诉我!

如果您运行 GitLab 作业,它通常具有您的 repo 的所有 git 历史记录。不过,在 git 和 GitLab 中都有一些设置会改变这一点,因此您必须确保始终将所有 git 历史记录用于pages工作。如果您有一个尚未添加到 git 的文件夹,例如public,则当您签出另一个分支时,git 不应更改其中的任何内容。

我认为您还应该能够设置带有时间表的 GitLab 页面作业,以便pages即使仅staging更新了分支而不是分支也可以运行该作业master

于 2019-11-25T12:58:12.423 回答