NetlifyからCloudflare Pagesに引っ越しました

目次

  1. 1. Cloudflare Pages について
  2. 2. 移行の理由
    1. 2.1. 無料プランが強い
    2. 2.2. CDNが強い
    3. 2.3. 無料でもBASIC認証が可能
    4. 2.4. 無料でも商用利用可(現時点では)
  3. 3. Cloudflare Pages への移行
    1. 3.1. Wrangler のインストール
    2. 3.2. Cloudflare にログインする
    3. 3.3. プロジェクト作成実行
  4. 4. Cloudflare Pages へのデプロイ
    1. 4.1. 不要なインデックスの回避
    2. 4.2. トークンの準備
    3. 4.3. GitHub Actions のワークフロー追加
      1. 4.3.1. CLOUDFLARE_ACCOUNT_ID
      2. 4.3.2. CLOUDFLARE_API_TOKEN
      3. 4.3.3. secrets に登録
      4. 4.3.4. ワークフロー作成
  5. 5. DNSの移行
    1. 5.1. Cloudflare 作業
    2. 5.2. Xserver Domain 側作業
    3. 5.3. Cloudflare の画面に戻って続き
    4. 5.4. カスタムドメインをアクティブ化
    5. 5.5. Netlify DNS のAレコード削除
  6. 6. その他の設定
    1. 6.1. .dev ドメインをクロールさせない
    2. 6.2. ネイキッドドメインへのリダイレクト
  7. 7. 実測
    1. 7.1. 体感ベース
    2. 7.2. Apache Bench
      1. 7.2.1. Netlify
      2. 7.2.2. Cloudflare Pages
    3. 7.3. PageSpeed Insights
      1. 7.3.1. デスクトップ
      2. 7.3.2. モバイル
  8. 8. 感想
cloudflare pages

最近、このブログのホスティング先を長年使っていた Netlify から Cloudflare Pages に変更しました。サイト自体は特に何も変えていないので、ここにアクセスしてくださっている(稀少な)方々は特に変化を意識することはなかったと思います。

その際に行った作業なんかを今日は書いていこうと思います。
(要所で画面キャプチャ撮りながらわりとガッツリ書いてみたらけっこうなボリュームになりました)

Cloudflare Pages について

Cloudflare Pages

Cloudflare Pages is a JAMstack platform for frontend developers to collaborate and deploy websites.

Cloudflare が提供する静的ホスティングサービスです。Netlify と同様に GitHub と連携して簡単に静的サイトをデプロイしたり、その他 Cloudflare の各種機能との連携による恩恵を受けることができます。

移行の理由

Netlify でもそこまで大きな不満はなかったのですが、主に下記の点で移行を決めました。

無料プランが強い

何を重視するかにもよって強みは変わりますが、まず無料プランでもリクエスト数と帯域幅が無制限であることが大きいです。このサイトだけであれば正直大してリクエストもこないのでどっちでもいいといえばそれまでではありますが、まあ制限がないにこしたことはないです。

CDNが強い

Netlifyが日本からだと遅い - id:anatooのブログ

これは上記も含めていろんなところで言われていますが、同じCDNでも Cloudflare と違い、Netlify は CDN のキャッシュサーバーが日本にはないため、サーバー応答が若干遅いと言われています。2023年1月時点ではこのへんだとシンガポールが最寄りのキャッシュサーバーになるようです。

https://answers.netlify.com/t/is-there-a-list-of-where-netlifys-cdn-pops-are-located/855

Regular CDN:

  • Central Europe (Frankfurt, Germany)
  • South America (Sao Paulo, Brazil)
  • Eastern US (New York, USA)
  • Western US (San Francisco, USA)
  • Asia (Singapore, Republic of Singapore)
  • Australia (Sydney, Australia)

対して Cloudflare は現時点で国内でも東京、大阪、福岡、那覇の4ヶ所にサーバーがありますのでこのへんは圧勝といえます。
Cloudflare Global Network | Data Center Locations | Cloudflare

ウチは静的ページを置いているだけなのでどのページもそこまで遅くはないのですが、爆速かと言われるとそこまでではないので、速くなるならやってみる価値はあると思いました。

無料でもBASIC認証が可能

Cloudflare Pages 自体の機能ではありませんが、Cloudflare Workers を利用してBASIC認証をつけることができます。無料でいけます。
HTTP Basic Authentication · Cloudflare Workers docs

Netlifyだと無料プランだとBASIC認証はつけることができません。
Netlify Pricing and Plans#BASIC AUTHENTICATION

たまに認証をかけたいページを作りたくなりますが、それが実現できるようになるのは大きいです。

無料でも商用利用可(現時点では)

公式フォーラムで中の人から無料プランでも商用利用OKとコメントがあります。

Is Cloudflare Pages, Workers free plan free for commercial use? - Developers / Cloudflare Pages - Cloudflare Community

一時期移転先候補として検討していた Vercel は無料プランによる商用利用をはっきり禁止事項に入れています。
Fair Use Policy | Vercel Docs

ウチのサイトは Google Adsense による広告を載せているため、Vercel は見送った次第です。とはいっても広告収入は雀の涙ですが\(^o^)/

Cloudflare Pages への移行

というわけで移行を進めていきます。
基本的には公式にガイドがあるのでこれを見つつ、ところどころ不要そうな作業をカットしたり、ウチでは必要なものを足したりしていきます。
Migrating from Netlify to Pages · Cloudflare Pages docs

Cloudflare にはサインアップ済み、という前提で話を進めます。まずは Cloudflare Pages に移行先プロジェクトがないと話にならないのでこれを作るところからスタートします。デプロイはコマンドで行うので、ここでは空のプロジェクトを作ります。

Wrangler のインストール

Wrangler は Cloudflare Workers のコマンドラインツールです。現時点では空プロジェクトの作成はコマンドラインからのみ可能であるため、まずは必要はCLIツールをインストールします。

# npm
npm install -g wrangler

# yarn
yarn global add wrangler

より詳しい情報はこちら
Install/Update Wrangler · Cloudflare Workers docs

Cloudflare にログインする

以下のコマンドを実行します。

wrangler login

ブラウザ上で許可を求められるので Allow を押します。

ログインコマンド

以下の画面が出たらこのページは閉じてOKです。

ログイン成功

ターミナル上にもログイン成功のメッセージが出たらログイン完了です。

$ wrangler login
⛅️ wrangler 2.14.0
--------------------
Attempting to login via OAuth...
Opening a link in your default browser: https://dash.cloudflare.com/oauth2/auth?response_type=code&client_id=***&redirect_uri=***&scope=***&state=***&code_challenge_method=S256
Successfully logged in.

プロジェクト作成実行

wrangler pages project create コマンドを実行するとプロジェクトの作成だけを行います。プロジェクト名とproduction branchはウチの場合なので必要に応じて読み替えてください。

wrangler pages project create
✔ Enter the name of your new project: … jpsern-web
✔ Enter the production branch name: … master
✨ Successfully created the 'jpsern-web' project. It will be available at https://jpsern-web.pages.dev/ once you create your first deployment.
To deploy a folder of assets, run 'wrangler pages publish [directory]'.

コマンドの実行が完了すると空のプロジェクトが Cloudflare Pages 上に作成されます。

空プロジェクト

Cloudflare Pages へのデプロイ

不要なインデックスの回避

先に Hexo プロジェクト側での作業を行います。 _headers というファイルを public フォルダに入れておきます。以前にやった _redirects と同じ要領です。

内容はこんなかんじです。

# カスタムドメインを割り当てる予定
# そのためデフォルトのURLでインデックスされないようにしています
# canonical も設定済みですが念のため
https://jpsern-web.pages.dev/*
X-Robots-Tag: noindex

Headers · Cloudflare Pages docs

トークンの準備

コマンドによるデプロイに必要なので取得しておきます

まず Cloudflare のダッシュボードにログインします。
https://dash.cloudflare.com/

カスタムトークンを作成するから「始める」をクリックします

トークン取得

必要事項を入れます。名前は適当です。要は Cloudflare Pages の編集権限を付与できればOKです。あとは一番下の「概要に進む」をクリックするだけです。日本語モードにしているけどなんか変な日本語。

権限の変更

問題なければ作成します。

確認画面

トークン表示画面が出ます。メッセージのとおり、この画面が出るのは1度きりなので、ここで忘れずにトークンを控えておきましょう。

トークン確認画面

GitHub Actions のワークフロー追加

公式がワークフローを提供しているので、それを使うのが簡単です。アカウントIDとトークンを事前に secrets に登録が必要です。
Use Direct Upload with continuous integration · Cloudflare Pages docs

CLOUDFLARE_ACCOUNT_ID

ダッシュボードのURLにくっついているのがそうです。

アカウントID

CLOUDFLARE_API_TOKEN

前述で控えてもらったトークンがこれです。

secrets に登録

こちらに画像付のわかりやすい例が書いてありますので詳しくは割愛します。
暗号化されたシークレット - GitHub Docs

下記のようにアカウントIDとトークンがリポジトリシークレットに登録されればOKです。

Secrets

ワークフロー作成

※2024/06修正
Cloudflare 公式の cloudflare/pages-action を使っていましたがしばらく保守が止まっているようでしたので cloudflare/wrangler-action を使うように変更しました。

.github/workflows/deploy-clf.yml

name: Deploy Clf
on:
push:
branches:
- master
workflow_dispatch:
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4

# ここにはサイトビルド用の記述を書いていますが
# 本筋とはズレるのでここでは省略しています

# Cloudflare Pages へのデプロイ
- name: Deploy to Cloudflare Pages
uses: cloudflare/wrangler-action@v3
with:
apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }}
accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
command: pages deploy ./public --project-name=jpsern-web --commit-dirty=true

これで、master ブランチに push すれば Cloudflare Pages へデプロイされるようになりました。

DNSの移行

CDNの恩恵を受けたいので、Netlify DNS から Cloudflare DNS への移行も行います。

Cloudflare 作業

カスタムドメインを設定しようとすると以下のように先に Cloudflare DNS の登録を指示されるのでそのままクリックして進めます。

カスタムドメインを設定をクリック

カスタムドメイン設定画面1

続行をクリック

カスタムドメイン設定画面2

DNS移行を開始をクリック

カスタムドメイン設定画面3

所持ドメインを入力

DNS設定1

ここは Free でOKです。

DNS設定2

自動でいくつかAレコードが入っていますが今回は全部必要ないです。

DNS設定3

Cloudflare Pages のサイトを以下のように指定します。

DNS設定4

ネームサーバーの変更を要求されるので、画面の手順どおりネームサーバーの変更を進めます。

ネームサーバー設定1

何に変更すれば良いかはこちらに記載されていますのでこれを控えておきます。「完了しました〜」のボタンはまだクリックしないでください。

ネームサーバー設定2

Xserver Domain 側作業

ウチのドメインは Xserver Domain でドメイン管理しているので、こっちの管理画面からネームサーバーの設定を行います。持ってるドメインはこのサイトのドメインくらいですが。下記のとおり Cloudflare から指定されたとおりの状態にします。

Xserver Domain画面

Cloudflare の画面に戻って続き

最後にドメインの詳細を設定します。何も考えずにひととおり有効にしておいてOKです。

クイックスタート設定1

このへんもお好みの範囲なので、ぽんぽん進めてOKです。ここでは全部有効にしました。

クイックスタート設定2

カスタムドメインをアクティブ化

Cloudflare DNS への登録が終わったら、登録したドメインをカスタムドメインに指定して、アクティブ状態になれば完了です。アクティブに変わるまではちょっと待ちます。wwwありとなしの2つ分設定してください。

custom-domains

Netlify DNS のAレコード削除

しばらくは Netlify DNS と Cloudflare DNS のAレコードが混在した状態になります。元のAレコードのTTL自体はそんなに長くはないはずですが、今回のようにネームサーバーを変更した場合は特に時間がかかるので、すぐには Netlify DNS のAレコードは削除せず、3日程度空けてから削除してください。(体感は半日くらいは新旧両方に飛んでいた気がします。)

その他の設定

まだならやっておきましょう。

.dev ドメインをクロールさせない

hexo の場合は public 配下に _headers ファイルを追加して対応します

https://jpsern-web.pages.dev/*
X-Robots-Tag: noindex

これで、.dev ドメインでアクセスされても大丈夫です。

ネイキッドドメインへのリダイレクト

wwwあり → wwwなし、へのリダイレクトは Cloudflare 側で設定します。

手順は以下のとおりです。
CloudflareのPage Rulesを理解した上で設定する(Page Rulesチュートリアル) · Cloudflare Support docs

ちなみに参考までにウチの設定例です。

こんなかんじで入力して

custom-domains

wwwなし→wwwありの設定が終われば完了です。

custom-domains

実測

体感ベース

ちょっとページ出るの速くなった気はしたものの、正直そこまで差は感じませんでした。もっと爆速感出るかと思っていました。まあ静的サイトなのでもともとそんなに遅くはなかったということもありますので、とりあえず逆効果にはなっていなさそうということでここではよしとします。

Apache Bench

どっちも何回かやって一番速かった結果を載せてみましたが、Cloudflare に移行してから劇的に速くなってますね。体感ではあまりわかりませんでしたが、確実に効果はあったようです。

Netlify

$ ab -n 10 https://jpsern.com/
This is ApacheBench, Version 2.3 <$Revision: 1879490 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking jpsern.com (be patient).....done


Server Software: Netlify
Server Hostname: jpsern.com
Server Port: 443
SSL/TLS Protocol: TLSv1.2,ECDHE-ECDSA-AES128-GCM-SHA256,256,128
Server Temp Key: ECDH X25519 253 bits
TLS Server Name: jpsern.com

Document Path: /
Document Length: 42669 bytes

Concurrency Level: 1
Time taken for tests: 5.235 seconds
Complete requests: 10
Failed requests: 0
Total transferred: 430220 bytes
HTML transferred: 426690 bytes
Requests per second: 1.91 [#/sec] (mean)
Time per request: 523.494 [ms] (mean)
Time per request: 523.494 [ms] (mean, across all concurrent requests)
Transfer rate: 80.26 [Kbytes/sec] received

Connection Times (ms)
min mean[+/-sd] median max
Connect: 214 260 86.4 218 424
Processing: 209 263 113.7 211 526
Waiting: 70 124 113.7 71 386
Total: 424 523 198.6 428 949

Percentage of the requests served within a certain time (ms)
50% 428
66% 430
75% 452
80% 845
90% 949
95% 949
98% 949
99% 949
100% 949 (longest request)

Cloudflare Pages

$ ab -n 10 https://jpsern.com/
This is ApacheBench, Version 2.3 <$Revision: 1879490 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking jpsern.com (be patient).....done


Server Software: cloudflare
Server Hostname: jpsern.com
Server Port: 443
SSL/TLS Protocol: TLSv1.2,ECDHE-RSA-CHACHA20-POLY1305,2048,256
Server Temp Key: ECDH X25519 253 bits
TLS Server Name: jpsern.com

Document Path: /
Document Length: 41098 bytes

Concurrency Level: 1
Time taken for tests: 0.584 seconds
Complete requests: 10
Failed requests: 0
Total transferred: 418496 bytes
HTML transferred: 410980 bytes
Requests per second: 17.13 [#/sec] (mean)
Time per request: 58.362 [ms] (mean)
Time per request: 58.362 [ms] (mean, across all concurrent requests)
Transfer rate: 700.26 [Kbytes/sec] received

Connection Times (ms)
min mean[+/-sd] median max
Connect: 13 17 5.0 16 29
Processing: 33 41 8.4 38 57
Waiting: 31 39 8.5 37 56
Total: 46 58 10.6 57 74

Percentage of the requests served within a certain time (ms)
50% 57
66% 66
75% 69
80% 70
90% 74
95% 74
98% 74
99% 74
100% 74 (longest request)

PageSpeed Insights

Netlify 時代のスコアを控え忘れましたが、たしかモバイルが76点ぐらいだった覚えがありますのでこちらもおそらく効果は数字に表れていると思います。

デスクトップ

デスクトップ

モバイル

モバイル

感想

1年半くらい前から乗り換えを考えていましたが、プレビューデプロイの要否を制限できなかったこと、CLIツールのデプロイ環境がまだ整っていなかったことからしばらく導入を見送っていましたが、だんだん機能が整備されてきてこのたびようやく引っ越しに至りました。

しばらくはこれで運用してみます。Cloudflare 側に無料なのにわりと多機能なアナリティクスもついてきているので、場合によってはGAやめてもいいかもしれません。Netlify と違ってまだ何もノウハウがないので、これから少しづつ使い倒してみようかと思います。

スポンサーリンク
share