GitLab Pages配置

环境准备阶段

首先确保项目可见性设置为Public(私有项目需要Premium版本才能使用Pages)。在项目根目录创建.gitlab-ci.yml文件,这是整个流程的触发点。建议同时创建public文件夹(如果使用Hugo/Jekyll等静态生成器可忽略),因为默认发布目录就是public。

基础配置实战

最简单的配置示例:

这里有个容易栽跟头的地方:artifacts路径必须设为public,且only分支要对应你的发布分支。遇到过缓存失效的情况,后来发现是job名称必须严格命名为"pages"(不能改其他名字),这个设计确实有点反直觉。

自定义域名配置

在Settings > Pages里添加域名后,需要创建CNAME文件到public目录。遇到过DNS解析生效但页面一直报证书错误,最后发现是Let's Encrypt证书需要等10分钟左右自动签发。如果要用HTTPS,注意别在域名里带www前缀,否则会触发证书校验失败。

高级技巧:动态环境

通过environment配置可以实现预览环境:

这里$CI_COMMIT_REF_SLUG变量会自动生成分支名的URL安全版本。实测发现带中文的分支名会编码成百分号格式,建议用英文命名分支。

权限控制要点

如果项目包含敏感信息,切记在Variables里设置保护变量时,不要勾选"暴露给分支"。有次误操作导致临时密码泄露,后来用环境作用域(environment scope)解决了这个问题。

故障排查记录

最常遇到的是404错误:首先检查public目录是否生成,其次查看CI流水线里Job的artifacts是否成功上传。有个隐藏坑点是.gitlab-ci.yml的缩进必须使用空格,用tab符会导致解析失败。另外如果使用静态站点生成器,记得把输出目录重命名为public(Hexo默认是public,但Jekyll是_site)。

性能优化建议

通过tag指定runner能显著提升构建速度,实测用docker executor比shell executor快3倍。另外可以在before_script里配置缓存:

不过要注意缓存键的设置,不同分支最好用不同缓存键,否则可能出现样式错乱。

最后提醒:绑定自定义域名后默认会强制HTTPS,如果遇到重定向循环,需要检查网站内链是否都是相对路径。上次就是因为绝对路径里写了http协议,导致浏览器安全策略拦截。现在每次部署完建议用curl -I检查返回头里的Location字段是否正确。

相关推荐
双层吉士憨包41 分钟前
掌握Facebook BM 提升广告账户稳定性
github
MindCareers1 小时前
Beta Sprint Day 5-6: Android Development Improvement + UI Fixes
android·c++·git·sql·ui·visual studio·sprint
TTGGGFF1 小时前
报错解决:git clone git@github.com: Permission denied (publickey)权限拒绝问题
git·github
数据大魔方1 小时前
【期货量化实战】威廉指标(WR)策略:精准捕捉超买超卖信号(Python源码)
开发语言·数据库·python·算法·github·程序员创富
tiandyoin2 小时前
visual studio 克隆 github 时,如何保持行尾符与 github 一致
ide·github·visual studio
吻等离子2 小时前
Git版本管理:掌握Git Checkout 回溯备份与标签管理
git
企鹅郁金香2 小时前
使用Docker部署Gitlab和Gerrit (一)
docker·容器·gitlab·gerrit部署
奔跑草-17 小时前
【AI日报】每日AI最新消息2026-01-06
人工智能·github
小龙17 小时前
[Git 报错解决]本地分支落后于远程分支(`non-fast-forward`)
大数据·git·elasticsearch·github
爱敲代码的婷婷婷.18 小时前
git 指定版本回退、临时保存 等操作
git