当前位置: 首页
编程语言
Git怎么创建GitHub Pages网站_Git部署静态网站到GitHub【实战】

Git怎么创建GitHub Pages网站_Git部署静态网站到GitHub【实战】

热心网友 时间:2026-05-01
转载

GitHub Pages 部署完全指南:从入门到精通,避开常见陷阱

Git怎么创建GitHub Pages网站_Git部署静态网站到GitHub【实战】

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

使用 GitHub Pages 搭建个人博客、项目文档或静态网站,是许多开发者的首选方案。其流程看似简单,但在实际操作中,新手常常会陷入几个典型的误区,导致部署失败或效率低下。本文将为你详细拆解 GitHub Pages 部署的核心步骤与关键细节,帮助你高效、稳定地完成网站发布。

关于部署分支:gh-pages 分支已非必选项

首先需要纠正一个广泛存在的认知误区:部署 GitHub Pages 网站并不强制要求使用 gh-pages 分支。这个分支更多是早期 Jekyll 工作流的遗留产物。如今,GitHub Pages 官方推荐并支持直接从 main(或 master)分支的根目录,或专门的 /docs 文件夹进行部署。刻意创建 gh-pages 分支反而会增加分支管理和同步的复杂度。

那么,当前推荐的部署方式有哪些?

  • 最简方案(根目录部署):将你的网站源码(如 index.html, style.css, script.js)直接提交到仓库的 main 分支根目录。随后,进入仓库的 Settings → Pages → Build and deployment,在 Source 部分选择 “Deploy from a branch”,分支选择 main,文件夹选择 /(root)
  • 代码与文档分离(/docs 目录部署):如果你希望将网站文件与项目源代码分开管理,可以在仓库中创建一个 docs 文件夹,将所有静态网站文件放入其中(例如 docs/index.html)。在 Pages 设置中,源分支选择 main,文件夹则选择 /docs
  • 访问与生效:保存设置后,GitHub 会提供一个格式为 https://<用户名>.github.io/<仓库名> 的访问地址。通常在一两分钟内,你的网站即可通过该链接访问。

部署工具选择:为何应避免使用 git subtree push

在网络上的老旧教程中,常会看到使用 git subtree push 命令将构建目录(如 dist/build/)推送到 gh-pages 分支的方法。这种方法在现代工作流中已被视为“反模式”,因为它会强制重写远程分支的提交历史,容易造成历史记录混乱,且在多人协作或误操作时可能导致线上内容被意外覆盖。

更现代、更可靠的部署策略推荐:

  • 自动化部署(首选):利用 GitHub Actions 实现自动化构建与部署。例如,对于 Jekyll 项目,可使用官方 Action actions/jekyll-build-pages;对于 VuePress、Hugo、VitePress 等静态站点生成器,社区广泛使用的 peaceiris/actions-gh-pages 是一个通用且强大的选择。
  • 手动部署(简单直接):对于纯静态文件,最直接的方式就是按照上述分支设置,将文件提交到指定目录(根目录或 /docs),然后执行 git push。这比任何复杂的 subtree 操作都更清晰、更安全。
  • 官方 CLI 工具:GitHub 官方命令行工具 gh 也提供了便捷的部署命令。安装并认证后,可以使用 gh pages deploy --dir ./dist 来部署指定目录。

自定义域名配置:完整步骤确保 HTTPS 强制启用

为 GitHub Pages 绑定自定义域名是常见需求,但许多用户在配置后会发现 HTTPS 无法强制开启,或网站访问异常。这通常是因为配置步骤不完整。要成功绑定域名并启用 HTTPS,必须完成以下三个环节:

  • 第一步:创建 CNAME 文件:在仓库的根目录或你选择的部署目录(如 /docs)下,创建一个名为 CNAME 的纯文本文件。文件内容仅有一行,即你的域名(例如 example.comwww.example.com)。关键提示:不要包含协议头(http/https),不要添加路径,文件末尾确保没有多余的空行或空格。
  • 第二步:在 GitHub 设置中配置:进入仓库的 Settings → Pages → Custom domain,输入与 CNAME 文件中完全一致的域名,并点击 Save。稍等片刻,待域名验证通过后,务必勾选下方出现的 Enforce HTTPS 复选框,以启用强制 HTTPS 访问。
  • 第三步:配置 DNS 解析:前往你的域名注册商或 DNS 服务商控制面板,添加 DNS 记录。
    • 若绑定的是根域名(如 example.com):通常需要添加 4 条 A 记录,分别指向 GitHub Pages 的 IP:185.199.108.153, 185.199.109.153, 185.199.110.153, 185.199.111.153
    • 若绑定的是子域名(如 www.example.com):添加一条 CNAME 记录,将主机记录指向 <你的用户名>.github.io

Jekyll 构建失败排查:编码与插件是关键

GitHub Pages 默认使用 Jekyll 静态站点生成器。如果你的仓库包含 Jekyll 项目文件,构建失败通常源于两个核心问题:_config.yml 配置文件编码错误,或使用了不受支持的第三方插件。

当收到构建失败通知时,可按以下流程排查:

  • 检查 YAML 文件编码:确保 _config.yml 文件使用 UTF-8 无 BOM 编码格式。带有 BOM(字节顺序标记)的 UTF-8 文件会导致 Jekyll 解析失败,错误信息常为 YAML Exception: invalid byte sequence in UTF-8。可以使用代码编辑器(如 VS Code、Sublime Text)检查并转换编码。
  • 排查第三方插件:GitHub Pages 仅支持其官方插件白名单中的插件。请暂时注释或移除 _config.ymlpluginsgems 字段下的非白名单插件,提交测试是否构建成功。
  • 彻底禁用 Jekyll:如果你的网站是纯静态文件,无需 Jekyll 处理,只需在仓库根目录放置一个名为 .nojekyll 的空文件。GitHub 检测到此文件后,将完全跳过 Jekyll 构建流程,直接托管原始文件。

总结来说,GitHub Pages 部署受阻,往往不是流程复杂,而是细节疏漏:DNS 记录生效需要时间(最长可达48小时)、CNAME 文件格式有误、或本地与 GitHub 服务器上的 Jekyll 版本存在差异。一个非常实用的建议是:遇到问题时,第一时间前往仓库的 Settings → Pages 页面,查看最新的构建日志(Build logs),其中的错误信息是定位问题最直接的依据。

来源:https://www.php.cn/faq/2311719.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
如何优化Apache2响应速度

如何优化Apache2响应速度

Apache2响应速度优化实操指南 想让你的Apache2服务器跑得更快?这事儿其实有章可循。下面这份实操指南,将从基础到进阶,帮你系统地提升响应速度。记住,所有优化都建立在不变动核心业务逻辑和架构的前提下。 一 基础与系统层面优化 优化得从地基开始。系统层面的几个关键设置,往往能以小成本换来大收益

时间:2026-05-01 22:39
git多人协作的工作流程【汇总】

git多人协作的工作流程【汇总】

多人协作必须禁用直接 push 到 main 分支:PR MR 流程是保障代码质量、自动化测试与冲突预判的核心机制;最佳实践包括语义化分支命名、启用分支保护规则,并规范 rebase 与 merge 的使用场景。 多人协作时,为什么禁止直接 push 到 main 分支? 直接向主分支推送代码,表面

时间:2026-05-01 22:39
CentOS上如何升级PHPStorm到最新版本

CentOS上如何升级PHPStorm到最新版本

在 CentOS 上升级 PhpStorm 的可选方案 说到在 CentOS 上升级 PhpStorm,其实路径很清晰。核心原则是:优先使用内置更新或 JetBrains Toolbox App 这类自动管理工具,其次才是手动下载安装包覆盖升级。下面,就按推荐顺序,把每种方式的操作步骤和关键要点给你

时间:2026-05-01 22:39
Atom如何设置自动保存?Atom自动保存功能开启教程

Atom如何设置自动保存?Atom自动保存功能开启教程

Atom如何设置自动保存?Atom自动保存功能开启教程 如果你还在为Atom的自动保存功能头疼,那很可能踩中了几个常见的“坑”。从1 27版本开始,autosa ve功能已经作为核心特性内置,不再依赖插件。但问题也随之而来:为什么设置了却不见效?答案往往藏在版本、配置层级,或者那些本该被清理的旧插件

时间:2026-05-01 22:39
如何在CentOS上备份PHPStorm的配置文件

如何在CentOS上备份PHPStorm的配置文件

在 CentOS 上备份 PhpStorm 配置文件:完整指南与最佳实践 一、备份前的准备工作 在开始备份 PhpStorm 配置之前,充分的准备工作至关重要。这能有效保障备份数据的完整性与安全性,避免因操作不当导致配置丢失或损坏。 彻底关闭 PhpStorm 应用程序:这是首要且必须的步骤。确保

时间:2026-05-01 22:38
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程