我可以在自托管实例上使用 GitLab 页面吗?
是的,GitLab Pages 适用于自托管实例。*.pages.<your-gitlab-domain-name>
如果您仅通过 https 运行 gitlab,您可能需要为 注册通配符域名,并生成 SSL 证书。
拥有域后,编辑/etc/gitlab/gitlab.rb
并添加额外的设置,然后运行(如果您仅通过 http 运行,gitlab-ctl reconfigure
请忽略设置:pages_nginx
gitlab_pages['enable'] = true
pages_external_url "https://pages.<your-gitlab-domain-name>"
pages_nginx['redirect_http_to_https'] = true
pages_nginx['ssl_certificate'] = "/etc/gitlab/ssl/pages.<your-gitlab-domain-name>.crt"
pages_nginx['ssl_certificate_key'] = "/etc/gitlab/ssl/pages.<your-gitlab-domain-name>.key"
完成后,您将能够通过以下方式访问每个项目的页面<group>.pages.<your-gitlab-domain-name>/<project>
我可以上传任何我想要的页面吗?
是的。每个 GitLab CI 作业都可以通过将内容写入public
文件夹并注册public
为工件目录来创建要在 GitLab 页面中发布的内容。最终pages
作业应该添加到 CI 管道中,这会导致页面内容被发布(覆盖之前存在的任何内容)。目录的所有内容public
都将通过<group>.pages.<your-gitlab-domain-name>/<project>
URL 提供,这意味着您可以完全控制内容。
请注意,CI 中的 pages 作业不需要任何脚本,它只需要与作业名称“pages”一起出现。这是一个触发页面发布的神奇作业名称。您可能希望添加作业限制,以便仅在主分支管道上运行。
我可以将页面发布添加到现有项目吗?
是的。创建您要发布的内容的任何步骤都应将内容写入public
子目录,并将该public
目录注册为工件目录。
my job:
stage: build
script:
- echo "Do some things and write them to public directory" > public/index.html
artifacts:
paths:
- public
expire_in: 2 weeks
注意:我喜欢添加expire_in: 2 weeks
以限制保留工件的时间长度。页面发布后,就不再需要这些工件了。
最后,您需要添加一个pages
作业来触发页面发布:
# This job does nothing but collect artifacts from other jobs and triggers the pages build
# The artifacts are picked up by the pages:deploy job.
pages:
stage: deploy
script:
- ls -l public
artifacts:
paths:
- public
only:
- master
通常您只想在 master 分支上发布,但您可以自由选择何时发布页面运行。重要的是要注意,当页面发布运行时,它将完全替换以前发布的任何内容,因此您不能附加到现有内容(尽管有一些技巧可以让您实现类似的东西)。