於 Cloudflare Pages 部署站點

贊助

成為我們的資助者或贊助商,以支持我們的工作。

贊助商

通過本文,你將學習到如何 Cloudflare Pages 上部署站點。

有多種方式將站點部署到 Cloudflare Pages.

通過 Cloudflare Pages 管理面板部署站點

  1. 登錄到 Cloudflare 管理面板。
  2. 打開 Pages 頁面。
  3. 點擊 Create a project 按鈕,然後選擇 Connect to Git.
  4. 選擇倉庫並點擊 Begin setup
  5. 填寫表單。
    1. 輸入項目名稱,Cloudflare 會給站點分配一個默認域名,顯示在輸入框下方。
    2. 選擇生產分支。
    3. 框架預設置:Hugo。
    4. 構建命令:其取決於你如何安裝構建工具,對於新手主題npm ci && hugo --gc --minify --enableGitInfo
    5. 構建輸出目錄:/public
    6. 確保 Build system version2,否則無法安裝 Dart Sass。
    7. 環境變量:
      1. HUGO_VERSION:比如 0.111.3
      2. NODE_VERSION:任意大於 16 的版本,如:19
      3. EMBEDDED_DART_SASS_VERSION:Embedded Dart Sass,如:1.62.1

通過 GitHub Cloudflare Pages Actions 部署站點

  1. 通過 Cloudflare Pages 管理面板 創建站點,並關閉其自帶的自動部署。
  2. 創建 CLOUDFLARE_ACCOUNT_ID1CLOUDFLARE_API_TOKEN2 action’s secrets
  3. 創建以下工作流程,並按需修改配置。
  4. projectName 替換爲你的站點名稱。
.github/workflows/cloudflare-pages.yaml
 1name: Cloudflare Pages
 2
 3on:
 4  # auto deploy when pushing to specified branches.
 5  push:
 6    branches:
 7      - main
 8
 9  # allow triggering workflow manually.
10  workflow_dispatch:
11
12jobs:
13  publish:
14    # Must runs on Ubuntu, since this workflow use snap to install Dart Sass.
15    runs-on: ubuntu-latest
16    permissions:
17      contents: read
18      deployments: write
19    name: Publish to Cloudflare Pages
20    steps:
21      - name: Checkout
22        uses: actions/checkout@v3
23
24      - name: Setup Node
25        uses: actions/setup-node@v3
26        with:
27          node-version: "19"
28
29      - name: Setup Dart Sass
30        run: sudo snap install dart-sass && sudo snap alias dart-sass sass
31
32      - name: Cache dependencies
33        uses: actions/cache@v3
34        with:
35          path: ~/.npm
36          key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
37          restore-keys: |
38            ${{ runner.os }}-node-
39
40      - name: Install dependencies
41        run: npm ci
42
43      - name: Setup Hugo
44        uses: peaceiris/actions-hugo@v2
45        with:
46          hugo-version: "latest"
47          extended: true
48
49      - name: Cache Hugo modules
50        uses: actions/cache@v3
51        with:
52          path: /tmp/hugo_cache
53          key: ${{ runner.os }}-hugomod-${{ hashFiles('**/go.sum') }}
54          restore-keys: |
55            ${{ runner.os }}-hugomod-
56
57      - name: Build
58        run: hugo --minify --gc --enableGitInfo
59        # Use following instead if defaultContentLanguageInSubdir is enabled.
60        # run: hugo --minify --gc --enableGitInfo && cp public/en/404.html public/404.html
61
62      - name: Publish to Cloudflare Pages
63        uses: cloudflare/pages-action@v1
64        with:
65          apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }}
66          accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
67          projectName: hb-theme
68          directory: ./public
69          # Optional: Enable this if you want to have GitHub Deployments triggered
70          gitHubToken: ${{ secrets.GITHUB_TOKEN }}

  1. 詳情請參閱 Get account ID。 ↩︎

  2. 另請參閱 Generate an API token。 ↩︎

razonyang
2025年1月18日 星期六 2023年3月5日 星期日