[{"data":1,"prerenderedAt":318},["ShallowReactive",2],{"content-/wife-blog-cloudflare-to-github-migration":3,"all-pages-for-dir":316,"og-image-/wife-blog-cloudflare-to-github-migration":317},{"id":4,"title":5,"body":6,"category":298,"description":299,"extension":300,"meta":301,"navigation":302,"ogImage":303,"path":304,"project_name":305,"published":306,"publishedAt":307,"seo":308,"stem":309,"tags":310,"todo":303,"unpublished":306,"updatedAt":303,"__hash__":315},"pages/2026-06/2026-06-27/wife-blog-cloudflare-to-github-migration.md","妻ブログを Cloudflare Pages Direct から GitHub 連携に切り替えるための手順メモ",{"type":7,"value":8,"toc":279},"minimark",[9,13,17,30,33,40,43,49,55,58,61,64,67,86,89,92,95,100,119,122,126,147,154,158,172,175,179,190,196,200,211,214,217,257,260,263,266,269,276],[10,11,12],"h2",{"id":12},"きっかけ",[14,15,16],"p",{},"妻のブログのディレクトリを開いて、ふと「これって自分の GitHub で管理してたっけ？」と手が止まった。リポジトリ名を確認したら自分のアカウント配下に確かにあった。ただ、デプロイ経路の記憶が曖昧で、Cloudflare Pages に Direct Upload で投げていたのか、GitHub 連携で動かしていたのかが思い出せない。",[14,18,19,20,24,25,29],{},"Claude Code に Cloudflare 側のプロジェクト設定を見てもらって、答えが出た。",[21,22,23],"strong",{},"Direct Upload で動いていた。"," ローカルから ",[26,27,28],"code",{},"wrangler pages deploy"," で直接ファイルを上げているタイプで、GitHub とは何も繋がっていない。",[10,31,32],{"id":32},"何が困るのか",[14,34,35,36,39],{},"このまま GitHub に push しても、Cloudflare 側は気付かない。妻が更新するたびに自分がローカルから手で ",[26,37,38],{},"wrangler"," を叩く運用になる。そもそも妻と自分で同じ環境を共有するなら、リポジトリの master を共通の真実にして、そこに push したら勝手にデプロイされる状態が望ましい。",[14,41,42],{},"ここで悩ましいのが、Cloudflare Pages の仕様。",[44,45,46],"blockquote",{},[14,47,48],{},"Direct Upload プロジェクトと Git 連携プロジェクトは「プロジェクト種別」として別物で、後から切り替えられない。",[14,50,51,52],{},"つまり、いま動いている Direct プロジェクトを途中から GitHub 連携に変更するボタンは存在しない。",[21,53,54],{},"作り直すしかない。",[10,56,57],{"id":57},"救いはドメインを自分が握っていること",[14,59,60],{},"一瞬「ドメイン移行が面倒だな」と肩を落としかけたが、よく考えたらドメインのレジストラ管理は自分でやっていて、Cloudflare のネームサーバーに向けているだけ。Cloudflare Pages のプロジェクトを作り直しても、新しいプロジェクト側にカスタムドメインを再紐付けすればそのまま使える。DNS の整合性さえ取れれば、ユーザー側からは何も変わらない。",[14,62,63],{},"影響範囲は Cloudflare Pages のプロジェクト再作成だけで済む、と判断した。",[10,65,66],{"id":66},"採用した運用イメージ",[68,69,70,74,77,80],"ul",{},[71,72,73],"li",{},"リポジトリの master に push → Cloudflare Pages が GitHub webhook を受けて自動ビルド → デプロイ",[71,75,76],{},"リポジトリは妻と Collaborator として共有",[71,78,79],{},"自分はドメインと Cloudflare 側のオーナーシップを保持",[71,81,82,83,85],{},"妻は記事を書いて push するだけ、ローカルから ",[26,84,38],{}," を叩く必要なし",[14,87,88],{},"「自分が管理、更新は妻」という非対称な役割分担に、GitHub 連携がきれいに当てはまる。",[10,90,91],{"id":91},"実際の手順",[14,93,94],{},"ここから先は、当日 Claude Code に整理してもらってカレンダーに貼ったメモの抜粋。",[96,97,99],"h3",{"id":98},"step-1-既存の-direct-プロジェクトを削除する","Step 1. 既存の Direct プロジェクトを削除する",[101,102,103,106,109,116],"ol",{},[71,104,105],{},"Cloudflare ダッシュボードにログイン",[71,107,108],{},"Workers & Pages → 対象のブログプロジェクトを開く",[71,110,111,112,115],{},"Custom domains タブでカスタムドメインを ",[21,113,114],{},"先に外す","（外さないと新プロジェクトに付け直せない）",[71,117,118],{},"Settings → Delete project でプロジェクトを削除",[14,120,121],{},"ここでドメインを先に剥がさないと、新プロジェクト側で「このドメインは既に他のプロジェクトに紐付いている」と弾かれる。剥がしてから消す、の順序を守る。",[96,123,125],{"id":124},"step-2-github-連携で新プロジェクトを作る","Step 2. GitHub 連携で新プロジェクトを作る",[101,127,128,131,134,141,144],{},[71,129,130],{},"Workers & Pages → Create application → Pages → Connect to Git",[71,132,133],{},"対象の GitHub リポジトリを選択",[71,135,136,137,140],{},"Production branch を ",[26,138,139],{},"master"," に設定",[71,142,143],{},"ビルドコマンド・出力ディレクトリをブログのスタックに合わせて入力",[71,145,146],{},"環境変数があれば登録",[14,148,149,150,153],{},"このタイミングで初回ビルドが走り、ビルド成功すれば Cloudflare 配下の ",[26,151,152],{},"*.pages.dev"," のサブドメインで一旦アクセスできる状態になる。",[96,155,157],{"id":156},"step-3-カスタムドメインを新プロジェクトに付け直す","Step 3. カスタムドメインを新プロジェクトに付け直す",[101,159,160,163,166,169],{},[71,161,162],{},"新プロジェクトの Custom domains タブで Add custom domain",[71,164,165],{},"手元のドメインを入力",[71,167,168],{},"DNS レコードを Cloudflare 側が自動で書き換えてくれる（同じネームサーバー配下なので一発）",[71,170,171],{},"数分待つと SSL 証明書が再発行される",[14,173,174],{},"ここが一番ハラハラする工程だが、ネームサーバーが Cloudflare に向いている前提なら、レコードの調整は Cloudflare 内部で完結する。",[96,176,178],{"id":177},"step-4-master-プッシュで自動デプロイを確認","Step 4. master プッシュで自動デプロイを確認",[101,180,181,184,187],{},[71,182,183],{},"ローカルで適当な変更（README に1行追記など）を加えて master に push",[71,185,186],{},"Cloudflare の Deployments タブで新しいデプロイがキューに入るのを目視",[71,188,189],{},"ビルドが緑で終わり、本番 URL に変更が反映されているかブラウザで確認",[14,191,192,193,195],{},"ここまで通れば、運用切り替え完了。以後は妻が記事を書いて push するだけで、自分が ",[26,194,38],{}," を叩く出番はなくなる。",[96,197,199],{"id":198},"step-5-リポジトリを妻と共有する","Step 5. リポジトリを妻と共有する",[101,201,202,205,208],{},[71,203,204],{},"GitHub のリポジトリ Settings → Collaborators",[71,206,207],{},"妻のアカウントを Collaborator として招待",[71,209,210],{},"妻側で招待を accept、ローカルに clone",[10,212,213],{"id":213},"ハマりどころ予防",[14,215,216],{},"ドキュメントに残しておきたかったのは、たぶん未来の自分が踏むであろう小さい罠。",[68,218,219,225,238,251],{},[71,220,221,224],{},[21,222,223],{},"カスタムドメインを剥がす前に旧プロジェクトを削除しない"," — ドメインが旧プロジェクトに紐付いたまま消すと、新プロジェクト側で再紐付けする際に「他プロジェクトと衝突」のエラーが出ることがある。先に剥がす。",[71,226,227,230,231,233,234,237],{},[21,228,229],{},"Production branch の名前を間違えない"," — 妻ブログのリポジトリは ",[26,232,139],{}," のまま運用しているので、デフォルトの ",[26,235,236],{},"main"," で作るとビルドが走らない。",[71,239,240,243,244,246,247,250],{},[21,241,242],{},"ビルドコマンドの設定を旧プロジェクトから引き継ぐ"," — Direct Upload では ",[26,245,38],{}," 側で完結していた処理が、GitHub 連携では Cloudflare ビルダー側に移る。",[26,248,249],{},"package.json"," の scripts と環境変数を確認しておく。",[71,252,253,256],{},[21,254,255],{},"環境変数を忘れない"," — Direct Upload では使っていなかった環境変数が、GitHub 連携プロジェクトのビルド時には必要になる場合がある（API キーなど）。",[10,258,259],{"id":259},"カレンダーに残す",[14,261,262],{},"「これ手順をドキュメントに残しておいてください。Google のスキル使って、カレンダーのメモ欄に貼っておいてください」と Claude Code に投げて、当日の 16 時に予定を作ってもらった。手順書はメモ欄に貼り付けてある。",[14,264,265],{},"将来「あ、これいつだったっけ」と探すとき、月日記事と Google カレンダーの両方から辿れる二重化。記事だけだと検索性が弱いし、カレンダーだけだと文章が消える。両方に置くと両方から思い出せる。",[10,267,268],{"id":268},"学び",[14,270,271,272,275],{},"形容詞で言えば「Cloudflare の Direct Upload は罠だった」になる。動詞で書き直すと、",[21,273,274],{},"Direct Upload で立ち上げたプロジェクトは GitHub 連携への切り替えボタンが存在せず、最初から作り直さないといけない。"," 立ち上げのときに何を選んだかで、後の運用の自由度が決まる。",[14,277,278],{},"最初の 1 分の選択が、後の 1 時間の作業を決める、というやつ。妻のブログだから影響は小さかったが、これがクライアント案件だったらと考えるとゾッとする。新規 Pages プロジェクトを作るときは、迷ったら GitHub 連携で始めるのを既定にしようと決めた。",{"title":280,"searchDepth":281,"depth":281,"links":282},"",2,[283,284,285,286,287,295,296,297],{"id":12,"depth":281,"text":12},{"id":32,"depth":281,"text":32},{"id":57,"depth":281,"text":57},{"id":66,"depth":281,"text":66},{"id":91,"depth":281,"text":91,"children":288},[289,291,292,293,294],{"id":98,"depth":290,"text":99},3,{"id":124,"depth":290,"text":125},{"id":156,"depth":290,"text":157},{"id":177,"depth":290,"text":178},{"id":198,"depth":290,"text":199},{"id":213,"depth":281,"text":213},{"id":259,"depth":281,"text":259},{"id":268,"depth":281,"text":268},"diary","妻のブログが Cloudflare Pages の Direct Upload で動いていたのを GitHub 連携プロジェクトに作り直して master プッシュで自動デプロイする運用に切り替えるための手順を整理し、カレンダーのメモ欄に残した記録。実際の切り替え作業は別日にまとめて行う。","md",{},true,null,"/wife-blog-cloudflare-to-github-migration","daily-log",false,"2026-06-27T00:00:00.000Z",{"title":5,"description":299},"2026-06/2026-06-27/wife-blog-cloudflare-to-github-migration",[311,312,313,314],"Cloudflare Pages","GitHub","デプロイ運用","妻ブログ","nw4ChRPBVF9ZJdVjkzfSMIZI9uBfjZWVIrhFgRG9g34",[],"https://log.eurekapu.com/og/blog/wife-blog-cloudflare-to-github-migration.png?v=2026-06-27T00%3A00%3A00.000Z&title=%E5%A6%BB%E3%83%96%E3%83%AD%E3%82%B0%E3%82%92%20Cloudflare%20Pages%20Direct%20%E3%81%8B%E3%82%89%20GitHub%20%E9%80%A3%E6%90%BA%E3%81%AB%E5%88%87%E3%82%8A%E6%9B%BF%E3%81%88%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AE%E6%89%8B%E9%A0%86%E3%83%A1%E3%83%A2&author=Kei%20Komatsu&sig=7dd415c342859992",1782885016562]