* docs: reorganize docs into en/cn/ja folders - Move documentation files into language-specific folders (en, cn, ja) - Add Chinese and Japanese translations for all docs - Extract Docker section from README to separate doc file - Update README to link to new doc locations * docs: fix links to new docs folder structure * docs: update README and provider docs * docs: fix broken import statements in cloudflare deploy guides * docs: sync CN/JA READMEs with EN structure and fix all paths
7.7 KiB
Cloudflare Workers へのデプロイ
このプロジェクトは OpenNext アダプター を使用して Cloudflare Worker としてデプロイすることができ、以下のメリットがあります:
- グローバルエッジへのデプロイ
- 超低レイテンシー
- 無料の
workers.devホスティング - R2 を介した完全な Next.js ISR サポート(オプション)
Windows ユーザー向けの重要な注意: OpenNext と Wrangler は、ネイティブ Windows 環境では完全には信頼できません。以下の方法を推奨します:
- GitHub Codespaces を使用する(完全に動作します)
- または WSL (Linux) を使用する
純粋な Windows 環境でのビルドは、WASM ファイルパスの問題により失敗する可能性があります。
前提条件
- Cloudflare アカウント(基本的なデプロイには無料プランで十分です)
- Node.js 18以上
- Wrangler CLI のインストール(開発依存関係で問題ありません):
npm install -D wrangler
- Cloudflare へのログイン:
npx wrangler login
注意: 支払い方法の登録が必要なのは、ISR キャッシュのために R2 を有効にする場合のみです。基本的な Workers へのデプロイは無料です。
ステップ 1 — 依存関係のインストール
npm install
ステップ 2 — 環境変数の設定
Cloudflare はローカルテスト用に別のファイルを使用します。
1) .dev.vars の作成(Cloudflare ローカルおよびデプロイ用)
cp env.example .dev.vars
API キーと設定を入力してください。
2) .env.local も存在することを確認(通常の Next.js 開発用)
cp env.example .env.local
同じ値を入力してください。
ステップ 3 — デプロイタイプの選択
オプション A: R2 なしでのデプロイ(シンプル、無料)
ISR キャッシュが不要な場合は、R2 なしでデプロイできます:
1. シンプルな open-next.config.ts を使用:
import { defineCloudflareConfig } from "@opennextjs/cloudflare/config"
export default defineCloudflareConfig({})
2. シンプルな wrangler.jsonc を使用(r2_buckets なし):
{
"$schema": "node_modules/wrangler/config-schema.json",
"main": ".open-next/worker.js",
"name": "next-ai-draw-io-worker",
"compatibility_date": "2025-12-08",
"compatibility_flags": ["nodejs_compat", "global_fetch_strictly_public"],
"assets": {
"directory": ".open-next/assets",
"binding": "ASSETS"
},
"services": [
{
"binding": "WORKER_SELF_REFERENCE",
"service": "next-ai-draw-io-worker"
}
]
}
ステップ 4 へ進んでください。
オプション B: R2 ありでのデプロイ(完全な ISR サポート)
R2 を使用すると Incremental Static Regeneration (ISR) キャッシュが有効になります。これには Cloudflare アカウントに支払い方法の登録が必要です。
1. R2 バケットの作成(Cloudflare ダッシュボードにて):
- Storage & Databases → R2 へ移動
- Create bucket をクリック
- 名前を入力:
next-inc-cache
2. open-next.config.ts の設定:
import { defineCloudflareConfig } from "@opennextjs/cloudflare/config"
import r2IncrementalCache from "@opennextjs/cloudflare/overrides/incremental-cache/r2-incremental-cache"
export default defineCloudflareConfig({
incrementalCache: r2IncrementalCache,
})
3. wrangler.jsonc の設定(R2 あり):
{
"$schema": "node_modules/wrangler/config-schema.json",
"main": ".open-next/worker.js",
"name": "next-ai-draw-io-worker",
"compatibility_date": "2025-12-08",
"compatibility_flags": ["nodejs_compat", "global_fetch_strictly_public"],
"assets": {
"directory": ".open-next/assets",
"binding": "ASSETS"
},
"r2_buckets": [
{
"binding": "NEXT_INC_CACHE_R2_BUCKET",
"bucket_name": "next-inc-cache"
}
],
"services": [
{
"binding": "WORKER_SELF_REFERENCE",
"service": "next-ai-draw-io-worker"
}
]
}
重要:
bucket_nameは Cloudflare ダッシュボードで作成した名前と完全に一致させる必要があります。
ステップ 4 — workers.dev サブドメインの登録(初回のみ)
初回デプロイの前に、workers.dev サブドメインが必要です。
オプション 1: Cloudflare ダッシュボード経由(推奨)
アクセス先: https://dash.cloudflare.com → Workers & Pages → Overview → Set up a subdomain
オプション 2: デプロイ時
npm run deploy を実行した際、Wrangler が以下のように尋ねてくる場合があります:
Would you like to register a workers.dev subdomain? (Y/n)
Y を入力し、サブドメイン名を選択してください。
注意: CI/CD や非対話型環境では、このプロンプトは表示されません。事前にダッシュボードで登録してください。
ステップ 5 — Cloudflare へのデプロイ
npm run deploy
スクリプトの処理内容:
- Next.js アプリのビルド
- OpenNext を介した Cloudflare Worker への変換
- 静的アセットのアップロード
- Worker の公開
アプリは以下の URL で利用可能になります:
https://<worker-name>.<your-subdomain>.workers.dev
よくある問題と解決策
You need to register a workers.dev subdomain
原因: アカウントに workers.dev サブドメインが登録されていません。
解決策: https://dash.cloudflare.com → Workers & Pages → Set up a subdomain から登録してください。
Please enable R2 through the Cloudflare Dashboard
原因: wrangler.jsonc で R2 が設定されていますが、アカウントで R2 が有効になっていません。
解決策: R2 を有効にする(支払い方法が必要)か、オプション A(R2 なしでデプロイ)を使用してください。
No R2 binding "NEXT_INC_CACHE_R2_BUCKET" found
原因: wrangler.jsonc に r2_buckets がありません。
解決策: r2_buckets セクションを追加するか、オプション A(R2 なし)に切り替えてください。
Can't set compatibility date in the future
原因: wrangler 設定の compatibility_date が未来の日付に設定されています。
解決策: compatibility_date を今日またはそれ以前の日付に変更してください。
Windows エラー: resvg.wasm?module (ENOENT)
原因: Windows のファイル名には ? を含めることができませんが、wasm アセットのファイル名に ?module が使用されているためです。
解決策: Linux 環境(WSL、Codespaces、または CI)でビルド/デプロイしてください。
オプション: ローカルでのプレビュー
デプロイ前に Worker をローカルでプレビューできます:
npm run preview
まとめ
| 機能 | R2 なし | R2 あり |
|---|---|---|
| コスト | 無料 | 支払い方法が必要 |
| ISR キャッシュ | なし | あり |
| 静的ページ | あり | あり |
| API ルート | あり | あり |
| 設定の複雑さ | シンプル | 普通 |
テストやシンプルなアプリには R2 なし を選んでください。ISR キャッシュが必要な本番アプリには R2 あり を選んでください。