Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Cloudflare Pages に入門してみた / 2023-10-14 Cloudflare Meetup Nagano Vol.2

Cloudflare Pages に入門してみた / 2023-10-14 Cloudflare Meetup Nagano Vol.2

Toro_Unit (Hiroshi Urabe)

October 14, 2023
Tweet

More Decks by Toro_Unit (Hiroshi Urabe)

Other Decks in Technology

Transcript

  1. $ whoami Toro_Unit / 占部 紘 Frontend & WordPress Engineer

    Github: @torounit Twitter: @Toro_Unit OSS Contributions WordPress / Gutenberg Team Shinshu WordPress Meetup 2
  2. 4

  3. やりたいこと CMS から記事を取得し表示 Stale-While-Revalidate (キャッシュの期限切れたら、裏側で新しいデータを取得してキ ャッシュを更新。その間は古いデータを返す。SWRとも呼ばれる。) 要は、Next.js を ISR で

    CMS と連携する時と同じことようなことがしたい! Note: ISR Incremental Static Regeneration SSG モードで使える。期限が切れたら裏で該当ページを再生成、完了後それを置き換え る。 記事更新時に全て再生成とかをしなくていいので非常に CMS とは相性が良い。 10
  4. 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
  5. 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
  6. やっていること どっちも Server Side Rendering (SSR) https://wordpress.org/news の記事を全件取得、巨大な配列に。その後、それ切り刻ん でページネーションしたり、フィルタリングして記事を表示したり。 記事数は1000件ほど。

    マジメにやるなら、データの持ち方とかもう少し考えた方が良い。 Astro の View Transition を使うと hover でリクエストが走って CPU limit で詰む。 17
  7. WordPress の API は一度に 100件までしか取得できない。 並列でリクエストを雑にすると Workers の制限で怒られるので、同時リクエスト数の制御が 必要。 そんなわけでまぁまぁ時間がかかる。

    1000件ほどの記事をとってきてるので遅い。重い。 リロードしまくるとCPU Limit に引っかかったり。 KV にキャッシュを作って、SWR 戦略で更新。 18
  8. 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
  9. まとめ Cloudflare Pages で、モダンなフレームワークガッツリSSR出来る! KV / D1 等と組み合わせるとかなりのことが出来る! ブラウザっぽい API

    がいっぱい出てくるのでフロントエンド屋に優しい? 銀の弾丸では無い! そうはいってもいろんなブレイクスルーの可能性はある! 20