GitHub PagesからCloudflare Pagesへの移行
Github Pages
から
Cloudflare Pages
に移行したときのメモを以下に記す。
背景
本ブログは、GitHub
でソース管理し、静的サイトジェネレーターHugo
で静的サイトを生成し、GitHub Pages
で公開している。
過去には、静的サイトホスティングサービスとして、Netlify
とCloudflare Pages
を使ったことがあったが、それぞれ次の理由で採用を見送っていた。
Netlify
: CDNのエッジサーバが日本になく、アクセスが遅いCloudflare Pages
: ビルド開始までに時間が掛かる(数分レベル)
しかし、2022年5月10日の記事
A new era for Cloudflare Pages builds
でCloudflare Pages
のビルド時間が改善したということを読んだ。
試してみると、確かにビルド時間が大幅に改善していたので、これを機会にCloudflare Pages
に移行した。
CDNの設定もうまくいっていなかったので今回合わせて対応した。
Cloudflare Pages側の操作
任意のGitHubリポジトリを選択するだけで、Cloudflare Pages
と連携できるのはNetlify
同様ありがたい。
次の手順で設定した。
PagesのCreate a project > Connect to Git
を選択
data:image/s3,"s3://crabby-images/76bf8/76bf818a3ba6ffa71854d0aa1efee56b208054a1" alt="Connect to Git"
「Deploy a site from your account」からHugoのリポジトリを選択
data:image/s3,"s3://crabby-images/fb23e/fb23e17e06b368a85e5ae0a229d55e75d08e3492" alt="Deploy a site from your account - Cloudflare Pages"
Set up build and deployments
data:image/s3,"s3://crabby-images/02342/02342c7e1e7d0f5afe108ae8ce991174e4d2d25d" alt="Set up build and deployments - Cloudflare Pages"
data:image/s3,"s3://crabby-images/be3df/be3dfa3b9bcd4de596770d78580b631c6fe6e80c" alt="Set up build and deployments - Cloudflare Pages"
Building and deploying
data:image/s3,"s3://crabby-images/899dd/899dd02c361a08e81c1f8b5a09a3ee53946c084d" alt="ALT"
data:image/s3,"s3://crabby-images/e7ab6/e7ab6ebebd5bfd3f04f3e65782d93faa25328198" alt="ALT"
data:image/s3,"s3://crabby-images/b4669/b466987a73a027ad14e04db4031b9654c0ae11b6" alt="ALT"
Hugo versionの指定
Hugo
でTailwindCSS v3
を利用する場合、現時点ではNode.js 16系が必要となるため、HUGO_VERSION
と合わせてNODE_VERSION
、NPM_VERSION
を、Settings > Environment variables
から指定した。
data:image/s3,"s3://crabby-images/583e8/583e842ee501b5772b66d9376eaa5cf23689cf92" alt="Cloudflare Pages Environment variables"
Webhook APIの生成
いまのところ、Cloudflare Pages
単体ではスケジュールビルドは実施できない。
そのため、スケジュールビルドのためにGitHub Action
を継続利用する。
Cloudfare Pages
では、Webhook APIが用意されている。
このWebhook APIをGitHub Action
から叩くことで、Cloudflare Pages
のビルドをキックする。
data:image/s3,"s3://crabby-images/a9f9e/a9f9e01d1f2338b2b4dd374d981354d0f899bf2a" alt="Webhook API"
GitHub(GitHub Pages)側の操作
GitHub Pagesへのpushデプロイを停止(Cloudflare Page側の自動ビルドに任せる)
https://github.com/meganii/www.meganii.com/commit/a98b16d5e95414583cbecbebfb39d88091d3082a
GitHub ActionでCloudflare PagesのWebhookを叩く
name: cloudflare pages
on:
schedule:
- cron: '30 10 * * *'
jobs:
deploy:
runs-on: ubuntu-20.04
steps:
- name: Deploy
run: curl -X POST "${{ secrets.CLOUDFLARE_PAGES_WEBHOOK }}"
GitHub Pagesの停止とドメイン切り替え
この部分は順番が前後している可能性もあるが、次の対応をした。
- GitHub Pagesの
Unpublish site
- Custom Domainの削除
data:image/s3,"s3://crabby-images/05033/0503344b811b0bf336aded1048f405e8bbc87332" alt="GitHub Pagesの停止とドメイン切り替え"
まとめ
Cloudflare Pages
は個人ブログとして使う分には申し分ない- Origin ServerとCDNをCloudflareにまとめることで、CDN配信周りを少し理解できた
Related contents
data:image/s3,"s3://crabby-images/5a8ef/5a8efd912cd7f1283b59321c5e2a8823791da5be" alt="Eyecatch"
TECH
2019.11.16
data:image/s3,"s3://crabby-images/b321f/b321f921ab7ffb917e138f0d140d720099a7114f" alt="Eyecatch"
TECH
2022.08.11
data:image/s3,"s3://crabby-images/7ad37/7ad37aa17850cc896131e3c5deb321442befe95e" alt="Eyecatch"
TECH
2023.02.03
data:image/s3,"s3://crabby-images/24c53/24c5341581288dfd196107ee00cdeb4a9fffe106" alt="Eyecatch"
TECH
2020.05.11
data:image/s3,"s3://crabby-images/7ad37/7ad37aa17850cc896131e3c5deb321442befe95e" alt="Eyecatch"
TECH
2020.03.13
data:image/s3,"s3://crabby-images/24c53/24c5341581288dfd196107ee00cdeb4a9fffe106" alt="Eyecatch"
TECH
2019.10.11
data:image/s3,"s3://crabby-images/24c53/24c5341581288dfd196107ee00cdeb4a9fffe106" alt="Eyecatch"
TECH
2019.10.06
data:image/s3,"s3://crabby-images/24c53/24c5341581288dfd196107ee00cdeb4a9fffe106" alt="Eyecatch"
TECH
2017.12.22