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
Next.js 16の新機能 Cache Components について
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
sutetotanuki
December 23, 2025
Technology
0
310
Next.js 16の新機能 Cache Components について
sutetotanuki
December 23, 2025
Tweet
Share
More Decks by sutetotanuki
See All by sutetotanuki
高速開発のためのコード整理術
sutetotanuki
1
390
Vercel AI SDK を使って Next.js で AIアプリケーションを 作成する方法のご紹介
sutetotanuki
0
1.6k
WEBエンジニア向けAI活用入門
sutetotanuki
0
870
ブラウザ上で実行され、 AIアシスタント付きデータベース postgres.new を触ってみた
sutetotanuki
0
410
今時のCookie事情
sutetotanuki
0
650
高速案件立ち上げで使われるマッハテンプレートのフロントエンド技術選定
sutetotanuki
2
1.9k
Core Web Vitals を改善する Next.js の機能群
sutetotanuki
1
2.5k
サーバーレスRDBの選択肢
sutetotanuki
0
1.5k
今日から始めるAmplify DataStore
sutetotanuki
0
1.4k
Other Decks in Technology
See All in Technology
Agile Leadership Summit Keynote 2026
m_seki
1
580
All About Sansan – for New Global Engineers
sansan33
PRO
1
1.3k
Azure Durable Functions で作った NL2SQL Agent の精度向上に取り組んだ話/jat08
thara0402
0
170
Codex 5.3 と Opus 4.6 にコーポレートサイトを作らせてみた / Codex 5.3 vs Opus 4.6
ama_ch
0
130
顧客の言葉を、そのまま信じない勇気
yamatai1212
1
350
Amazon Bedrock Knowledge Basesチャンキング解説!
aoinoguchi
0
130
制約が導く迷わない設計 〜 信頼性と運用性を両立するマイナンバー管理システムの実践 〜
bwkw
3
920
Bill One急成長の舞台裏 開発組織が直面した失敗と教訓
sansantech
PRO
2
350
レガシー共有バッチ基盤への挑戦 - SREドリブンなリアーキテクチャリングの取り組み
tatsukoni
0
210
FinTech SREのAWSサービス活用/Leveraging AWS Services in FinTech SRE
maaaato
0
130
Bedrock PolicyでAmazon Bedrock Guardrails利用を強制してみた
yuu551
0
200
[CV勉強会@関東 World Model 読み会] Orbis: Overcoming Challenges of Long-Horizon Prediction in Driving World Models (Mousakhan+, NeurIPS 2025)
abemii
0
110
Featured
See All Featured
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1k
4 Signs Your Business is Dying
shpigford
187
22k
Music & Morning Musume
bryan
47
7.1k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2k
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.6k
Google's AI Overviews - The New Search
badams
0
900
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.3k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
640
Product Roadmaps are Hard
iamctodd
PRO
55
12k
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
9.5k
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
320
Transcript
Next.js 16の新機能 Cache Components について 1
2 自己紹介 西田将幸 クラスメソッド リテールアプリ共創部 マッハチーム エンジニアとして働いてます 主にバックエンドでフロントエンドFlutterと薄く広くやってます
3 全体の流れ 1. Cache Componentsとは? 2. Cache Componentsの仕組み 3. 自作した
CloudFront + SSG の構成との比較
4 Cache Componentsとは?
5 Cache Componentsとは? • Next 16 で正式に採用された機能 • 1つのページにキャッシュさせた静的コンテンツと 動的コンテンツを共存させることができる
6 静的な要素と動的な要素が混在 全ユーザー共通のキャッ シュしても問題ない静的な 要素 と ユーザー固有の動的な要 素が1つのページに混在 してる
7 使い所の例 1. ECサイト ◦ 商品ページは全てのユーザーで共通なのでキャッシュしたい が、ヘッダにはログインしたユーザー名やカート情報など、 ユーザー特有の情報を表示させたい 2. 会員制のブログ
◦ コンテンツ自体は全てのユーザーで共通だが、ユーザーのプ ロフィールがサイドバーに表示されている
8 準備 next.config.ts で cacheComponents を true を設定
9 使い方 “use cache” ディレクティブを宣言する
10 useCache を指定できる範囲 • コンポーネント • 関数 • ページ
11 今までのキャッシュとの違い 1. いままでのキャッシュ ◦ fetch関数がデフォルトでキャッシュ キャッシュさせたくない場合は明示的にオプトアウト 2. “use cache”
以降のキャッシュ ◦ “use cache” ディレクティブが宣言されたところが キャッシュされる。オプトイン
12 Suspenseで動的部分を囲う 動的な部分は <Suspense> で囲う
13 Suspenseで動的部分を囲う
14 cacheLife cacheLifeでcacheの有効期限を設定
15 cacheLifeのオプション cacheLifeのオプション プロファイル ユースケース stale revalidate expire default 標準コンテンツ
5分 15分 1年 seconds リアルタイムデータ 30秒 1秒 1分 minutes 頻繁に更新されるコンテンツ 5分 1分 1時間 hours 1日に複数回更新されるコンテンツ 5分 1時間 1日 days 毎日更新されるコンテンツ 5分 1日 1週間 weeks 毎週更新されるコンテンツ 5分 1週間 30日 max ほとんど変更されない安定したコンテンツ 5分 30日 1年
16 cacheLifeのオプション
17 updateTag, revalidateTag 明示的にキャッシュを削除する時はupdateTag, revalidateTag を使う 例えばコンテンツを更新するような操作が行われときに明示 的にキャッシュをクリアします
18 updateTag, revalidateTag キャッシュにタグ名を設定し タグ名を指定してキャッシュを削除
19 use cache: remote キャッシュをサーバーに残す指定
20 use cache: private キャッシュをサーバーのメモリに残さない指定
21 React の Activity React 19 で使えるようになったコンポーネントで unmount さ れても状態を保持する
22 Next.js のクライアントナビゲーションで状態保持 next.config で cacheComopnents が true になってる場合、ク ライアントナビゲーションで画面遷移しても
ステートの値が保持されます
23 Cache Componentsの仕組み
24 Application Shell Architecture あらかじめサーバからはスケルトンのHTML,CSS,JSを アプリに返却し高速に初期表示を行い、 後から動的なコンテンツを注入する手法 高速な初期表示と動的な要素の表示を実現する方法
25 Application Shell Architecture
26 use cacheのコンテンツは静的シェルに含められる “use cache” を宣言されたコンテンツは、 キャッシュされ静的シェルに含められる
27 use cacheのコンテンツは静的シェルに含められる “use cache” されたコンテン ツは静的シェルに含められ るので初回表示は遅くなる 2回目位以降は高速
28 RSCペイロード React Server Component ペイロード サーバーでレンダリングされた情報をシリアライズ それをクライアントで組み立てる クライアントナビゲーションで画面遷移した際は RSC
Payload のみクライアントに送信 “use cache” されてない動的要素は RSC で送信される
29 use cacheのコンテンツは静的シェルに含められる 静的シェルの後に RSCペイロードを送信 その間 Suspense の fallbackが表示
30 自作した CloudFront + SSG の構成との比較
31 同じような目的で自作した構成 • 1つのNext.jsだけで 構成 • S3 + CFで WEBホスティング
• API Routes で動的 要素をAPIで提供
32 自作した構成 • 事前にStatic ExportしたHTML,CSS,JSをS3 + CloudFront で WEBホスティング •
動的な情報を返却するAPIを提供する App Runner でデプ ロイ • 静的なコンテンツはビルドして、動的なコンテンツは useEffect を使ってデータ取得(useEffectの処理はクライア ント側で実行される)
33 AWSでNext.jsシンプルに動かす構成 • ALB + Fargate
34 自作した構成 • “use cache” キャッシュされたコンテンツはサーバー上のメ モリにキャッシュされる • キャッシュされたコンテンツもサーバーで処理する •
Cloud Front + S3 の低コストで安定したキャッシュは出来な い
35 Vercelで動かすと...? • おそらく、静的シェルはエッジにキャッシュされる? • 高速に動くし、安定稼働は期待できそう...? • コストは自作より高くなるかも...?
36 まとめ
37 まとめ • “use cache” ディレクティブでオプトインのキャッシュができ るように • 1ページに静的、動的なコンテンツが両方あるけど 高速表示したい時に使える
プロダクトの0→1⽴ち上げ 専⾨チーム ⼀緒に働く仲間を募集...! モダンな技術スタックを積極採用 • Hono, V0, Claude Code… 顧客と0距離
• プリセールス ~MVPリリースまで • 顧客対応も 2~3名の小規模チームで高速開発 • 1案件 2~6ヶ月 • マッハで経験が積める 📢マッハチーム 絶賛募集中
39