Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Cloudflare Pages に入門してみた / 2023-10-14 Cloudflar...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Toro_Unit (Hiroshi Urabe)
October 14, 2023
Technology
2.3k
2
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Cloudflare Pages に入門してみた / 2023-10-14 Cloudflare Meetup Nagano Vol.2
Toro_Unit (Hiroshi Urabe)
October 14, 2023
More Decks by Toro_Unit (Hiroshi Urabe)
See All by Toro_Unit (Hiroshi Urabe)
ブロックテーマ、WordPress でウェブサイトをつくるということ / 2026.02.07 Gifu WordPress Meetup
torounit
0
700
ブロックテーマでサイトをリニューアルした話 / 2026-01-31 Kansai WordPress Meetup
torounit
0
590
ブロックテーマとこれからの WordPress サイト制作 / nishinomiya.dev@2025-12-21
torounit
1
280
ブロックテーマとこれからの WordPress サイト制作 / Toyama WordPress Meetup Vol.81
torounit
0
810
ブロックテーマ時代における、テーマの CSS について考える Toro_Unit / 2025.09.13 @ Shinshu WordPress Meetup
torounit
0
790
ブロックテーマでサイトリニューアルした話 / Toro_Unit / 2025.04.12 @ Shinshu WordPress Meetup
torounit
1
340
Cloudflare Meetup Nagano Vol.3
torounit
1
170
僕が考える 「HTML サイトを WordPress にする」話 / 2023-11-05 Kansai WordPress Meetup
torounit
9
8.8k
ブロックエディタをゴリゴリに使い倒してサイトを作った話 / Kansai WordPress Meetup 2023 09 23
torounit
15
11k
Other Decks in Technology
See All in Technology
【NRUG vol.18】KubernetesにおけるNew Relicデータ取得量削減の考え方
nrug_member
0
170
2026TECHFRESH畢業分享會 - Lightning Talk - E起 See See : 電商推薦讀心術? 數據說了算
line_developers_tw
PRO
0
1.3k
AIはどのように 組織のアジリティを変えるのか?
junki
4
1k
Flow 不死:AI 時代 DevOps 的不變本質
cheng_wei_chen
2
330
2026年6月23日 Syncable Tech + Start Python Club にて
hamukazu
0
140
LayerXにおけるセキュリティ管理の現在地と次の一手
tosho
0
250
Agent Skills設計で柔軟性と硬さのバランスが難しい話
nassy20
0
140
200個のGitHubリポジトリを横断調査したかった
icck
0
140
データレイクの「見えない問題」を可視化する
sansantech
PRO
1
100
SONiCのLinuxベースを活かしたZabbix監視
sonic
0
230
データサイエンスを価値につなげるプロジェクト設計 〜 DS一年目が現場で得た気づき 〜
ysd113
1
280
2026TECHFRESH畢業分享會 - 葬送的通靈師:化系統與用戶雜訊成行動訊號
line_developers_tw
PRO
0
1.3k
Featured
See All Featured
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
66
55k
Speed Design
sergeychernyshev
33
1.9k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
850
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Technical Leadership for Architectural Decision Making
baasie
3
420
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
220
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
Paper Plane
katiecoart
PRO
1
51k
Transcript
Cloudflare Pages に入門してみた Toro_Unit / 2023.10.14 @ Cloudflare Meetup Nagano
Vol.2 1
$ whoami Toro_Unit / 占部 紘 Frontend & WordPress Engineer
Github: @torounit Twitter: @Toro_Unit OSS Contributions WordPress / Gutenberg Team Shinshu WordPress Meetup 2
現代の Web サイト開発を支える技術 3
4
Jamstack Jamstackとは? Jamstackは、主にJavaScript、API、マークアップ(HTML/CSS)を用いて、高速かつ 軽量なWebアプリケーションを構築するための手法です。 https://www.cloudflare.com/ja-jp/learning/performance/what-is-jamstack/ 近年の WEB サイト/アプリ開発で広く用いられているアーキテクチャ。 サーバーレスアーキテクチャと関係が深い。 全部がこれに置き換わったわけでもなく、WordPress
とかも全然現役。 5
Cloudflare Pages Jamstack ホスティングサービス。 最初は静的サイトのホスティングだったはずな のに、Pages Functions で動的なサイトも全然 作れる。 6
Next.js 2016年リリース React を使ったフレームワーク この手のフレームワークではトップシェア SSG / SSR / ISR
など様々な HTML の生成方法 React Server Components にも対応 Vercel 社製 7
Next.js は良いんだけど... 全機能をフルに使うには、とりあえず Vercel を利用するのが安パイ かなり Vercel の機能を密結合なため、他のサービスで動かすのは少し大変。 他のサービスだと一部機能が使えないとかがあったり。 もしくは自前でコンテナ立てたり。
https://nextjs.org/docs/pages/building-your-application/deploying 8
Jamstack on Cloudflare 9
やりたいこと CMS から記事を取得し表示 Stale-While-Revalidate (キャッシュの期限切れたら、裏側で新しいデータを取得してキ ャッシュを更新。その間は古いデータを返す。SWRとも呼ばれる。) 要は、Next.js を ISR で
CMS と連携する時と同じことようなことがしたい! Note: ISR Incremental Static Regeneration SSG モードで使える。期限が切れたら裏で該当ページを再生成、完了後それを置き換え る。 記事更新時に全て再生成とかをしなくていいので非常に CMS とは相性が良い。 10
Remix 2021年リリース React Router の作者が作った後発のフレームワ ーク 割とどこでも動く。 シンプルな構成 Server Side
Rendering (SSR) のみ。 Focused on web standards and modern web app UX, you’re simply going to build better websites 11
for Cloudflare Pages npx create-remix --template remix-run/remix/templates/cloudflare-pages for Cloudflare Workers
npx create-remix --template remix-run/remix/templates/cloudflare-workers とりあえず、Pages でやっとけばよさそう。 12
やってみた https://remix-on-cloudflare-pages.torounit.dev https://github.com/torounit/remix-on-cloudflare-pages.torounit.dev 13
Astro 2022年リリース。現在再注目のフレームワー ク。 めっちゃ速い、クライアントサイドでJSを生成 する量が少ない。 デフォルトでは、クライアントサイドでJS を生成しない。 React とか Vue
とかを部分的に混ぜて使ったり も出来る Static Site Generation (SSG) も SSR も出来る 14
npm create cloudflare@latest astro-cf-pages -- --framework=astro 15
やってみた https://astro-on-cloudflare-pages.torounit.dev https://github.com/torounit/astro-on-cloudflare-pages.torounit.dev 16
やっていること どっちも Server Side Rendering (SSR) https://wordpress.org/news の記事を全件取得、巨大な配列に。その後、それ切り刻ん でページネーションしたり、フィルタリングして記事を表示したり。 記事数は1000件ほど。
マジメにやるなら、データの持ち方とかもう少し考えた方が良い。 Astro の View Transition を使うと hover でリクエストが走って CPU limit で詰む。 17
WordPress の API は一度に 100件までしか取得できない。 並列でリクエストを雑にすると Workers の制限で怒られるので、同時リクエスト数の制御が 必要。 そんなわけでまぁまぁ時間がかかる。
1000件ほどの記事をとってきてるので遅い。重い。 リロードしまくるとCPU Limit に引っかかったり。 KV にキャッシュを作って、SWR 戦略で更新。 18
KV を用いてキャッシュ KVにデータを保存するときに TTL が設定出来るので、雑にキャッシュを実装できる。 await NAMESPACE.put(key, value, { metadata:
{ expirationTtl: 60 * 60 }, }); Workers の、 context.waitUntil() も使えるので、リクエストを返却しつつ裏でキャッシ ュの更新が可能。remix の場合は、server.ts をちょっと変更する必要あり。 https://zenn.dev/yusukebe/articles/647aa9ba8c1550#12.動的コンテンツのキャッシュ を 参考に実装。 Fresh と Stale に更新時に同じデータをTTLを変えて保存。Fresh からデータが返ってこなか ったら、Stale を返却し、waitUntil を用いて裏でキャッシュを更新。 19
まとめ Cloudflare Pages で、モダンなフレームワークガッツリSSR出来る! KV / D1 等と組み合わせるとかなりのことが出来る! ブラウザっぽい API
がいっぱい出てくるのでフロントエンド屋に優しい? 銀の弾丸では無い! そうはいってもいろんなブレイクスルーの可能性はある! 20
最適なアーキテクチャを考えよう!ベストプラクティスを一緒にみつけよう! 21
Thanks! Github: @torounit Twitter / WP.org: @Toro_Unit torounit.com 22