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
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimizat...
Search
shiro seike
PRO
March 20, 2026
Programming
280
2
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimization Driven by Telemetry Signals
PHPerKaigi2026
https://phperkaigi.jp/2026/
shiro seike
PRO
March 20, 2026
More Decks by shiro seike
See All by shiro seike
コミュニティの有益性 ~JAWS Days 2026 での体験を通して~ / The Benefits of a Community ~Through My Experience at JAWS Days 2026~
seike460
PRO
0
270
Architecture as SteeringOn-Ramp to AI-DLC
seike460
PRO
0
27
Why Continue AWS Community Builders
seike460
PRO
0
73
AWSコミュニティ活動は顧客のクラウド推進に効くのか / Do AWS community activities help customers adopt the cloud?
seike460
PRO
0
180
AI-DLC 入門 〜AIコーディングの本質は「コード」ではなく「構造」〜 / Introduction to AI-DLC: The Essence of AI Coding Is Not “Code” but “Structure”
seike460
PRO
0
1.6k
今さら聞けないサーバーレスのいいところ 〜運用から解放される世界を目指して〜 / The Benefits of Serverless You Might Be Too Embarrassed to Ask About Now — Aiming for a World Free from Operational Burdens
seike460
PRO
0
110
AWS Lambda Durable Functions のユースケースを探る / Exploring Use Cases for AWS Lambda Durable Functions
seike460
PRO
0
96
歴史から学ぶ「Why PHP?」 PHPを書く理由を改めて理解する / Learning from History: “Why PHP?” Rediscovering the Reasons for Writing PHP
seike460
PRO
0
530
Team-First Serverless Platform Engineering Approach to PHP Applications with Laravel and Bref
seike460
PRO
1
160
Other Decks in Programming
See All in Programming
Inside Stream API
skrb
1
770
なぜ型を書くのか? TSKaigi2026で改めて考える #tskaigi_smarthr
kajitack
0
140
Developing with AI Agents — Codex, Claude Code & Cowork Practical Guide
x5gtrn
PRO
0
1.3k
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
280
才能?センス?知らん、 続けたもん勝ちだ。-- 結婚・出産・癌を越えてなお、私がプロダクトを創り続ける理由
16bitidol
1
270
ランチタイムLT会3周年!ランチタイムLT会を3年間続けられたお話
y0hgi
1
100
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
360
act1-costs.pdf
sumedhbala
0
110
Claspは野良GASの夢をみるか
takter00
0
210
エージェンティックRAGにAWSで入門しよう!
har1101
9
1.7k
Snowflake Summitでの新機能 CoCo / CoWork / snowflake-summit-2026-overall-what-new-coco
tatsuhiro
1
180
Strategic Design in the Frontend: Moduliths & Micro Frontends @DDDEurope
manfredsteyer
PRO
0
130
Featured
See All Featured
Six Lessons from altMBA
skipperchong
29
4.3k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
1.1k
How to Ace a Technical Interview
jacobian
281
24k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.8k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
310
New Earth Scene 8
popppiees
3
2.4k
Marketing to machines
jonoalderson
1
5.5k
Speed Design
sergeychernyshev
33
1.9k
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
250
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
160
Claude Code のすすめ
schroneko
67
230k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
66
55k
Transcript
©Fusic Co., Ltd. CONFIDENTIAL OSEKKAI × TECHNOLOGY テレメトリーシグナルが導くパフォーマンス最適化 PHPerKaigi 2026
2026.03.20 清家史郎 @seike460
©Fusic Co., Ltd. 自己紹介 はじめに 清家 史郎 (@seike460) SHIRO SEIKE
株式会社Fusicプリンシパルエンジニア/エバンジェリスト AWS User Group Leaders AWS Community Builder Serverless 2025 Japan AWS Top Engineers JAWS Days 2026 実行委員長
©Fusic Co., Ltd. アジェンダ
©Fusic Co., Ltd. 「なんか遅いんだよね」 • 勘と経験で 推測 する改善 • 本当に速くなったか
答えられない
©Fusic Co., Ltd. 推測するな、計測せよ • "Don't tune until you've measured"
• 計測には 3つのシグナル が必要
©Fusic Co., Ltd. • CNCF公式の ベンダーフリー テレメトリ基盤 • PHP: PECL拡張で
コード変更ゼロ計装 OpenTelemetry — 計測の標準基盤
©Fusic Co., Ltd. テレメトリパイプラインの設計
©Fusic Co., Ltd. 属性設計 — シグナルに意味を持たせる • api.version 属性で V1/V2
を区別 • Metrics のラベルとしても自動伝播
©Fusic Co., Ltd. 今日のサンプルアプリ : BookShelf API • V1 ボトルネックあり
/ V2 最適化済み • Docker Compose で 1コマンド起動
©Fusic Co., Ltd. 今日のサンプルアプリ : BookShelf API • V1 ボトルネックあり
/ V2 最適化済み • Docker Compose で 1コマンド起動
©Fusic Co., Ltd. Traces — ボトルネックを可視化する • 自動計装 がスパンツリーを自動生成 •
ウォーターフォールで 時間の内訳 が一目瞭然
©Fusic Co., Ltd. ボトルネック 1: N+1クエリ — V1 /books •
Book::all() — ページネーションなし • $book->author — 都度SELECT発行
©Fusic Co., Ltd. V1 トレース実測 : 50,009スパン / 約62秒 •
GET /api/v1/books の 実測 トレースデータ • 50,009スパン の異常なDB操作
©Fusic Co., Ltd. V2 の修正: Eager Loading + Pagination •
with() で N+1を解消 • paginate(20) で 20件ずつ 取得
©Fusic Co., Ltd. V2 トレース: 23スパン / 23ms 約2,700倍の改善 V1
V2 改善 レイテンシ 62,370ms 23ms ~2,700x スパン数 50,009 23 2,174x SQLクエリ ~10,001 4 2,500x
©Fusic Co., Ltd. ボトルネック 2: 同期外部API — V1 /orders
©Fusic Co., Ltd. Traces のウォーターフォール : 約5.5秒の内訳 • DB操作は 100ms以下
— 処理時間の 0.3% • 残り 99.7% は外部API + sleep
©Fusic Co., Ltd. V2 の修正: 非同期Job化 • 重い処理を Queue Job
にオフロード • 5,537ms → 1,017ms (約5倍改善)
©Fusic Co., Ltd. Metrics — 改善効果を計測する • Traces = 点の分析
/ Metrics = 線の監視 • spanmetrics で RED Metrics 自動生成
©Fusic Co., Ltd. spanmetrics connector Traces から Metrics を自動生成
©Fusic Co., Ltd. V1 vs V2 レイテンシ比較 — 実データ エンドポイント
V1 p95 V2 p95 改善率 GET /books 62,370ms 23ms ~2,700x POST /orders 5,537ms 1,017ms ~5x GET /books/{id} 35ms 29ms 1.2x GET /books/search 396ms 28ms ~14x
©Fusic Co., Ltd. Grafana ダッシュボード — 継続的な監視 • api_version ラベルで
V1/V2 比較 • V1/V2 比較 をリアルタイム監視
©Fusic Co., Ltd. カスタムメトリクスの設計
©Fusic Co., Ltd. Logs — コンテキストを補完する • trace_id でログへ直接ジャンプ •
構造化ログ で検索・フィルタ可能に
©Fusic Co., Ltd. Logs でバグを発見 : cache テーブル欠損
©Fusic Co., Ltd. 3シグナルの相関 — Trace IDで紐づける • spanmetrics で自動変換
• Exemplar で逆引き • これらをOpenTelemetryMCPを利用して「データソース」 に出来る
勘と経験に頼らず シグナルが導く改善を始めよう
©Fusic Co., Ltd. 本番運用の知見 • コスト・パフォーマンス・データ量の バランス • デモ環境と本番は 別物
©Fusic Co., Ltd. サンプリング戦略 • Head-based: 開始時に確率判定 • Tail-based: 完了後に条件判定
©Fusic Co., Ltd. Tail-based サンプリングの実践 • エラー/遅延トレースは 100% 収集 •
正常トレースは 10% サンプリング
©Fusic Co., Ltd. Collector 構成: memory_limiter と batch • memory_limiter:
512MiB 上限 • batch: 1024スパン ごと送信
©Fusic Co., Ltd. spanmetrics: カーディナリティに注意 • dimension 過多で メトリクス爆発 •
値が有限な属性だけを選ぶ
©Fusic Co., Ltd. 今日から始める 3ステップ • 計装 → 収集 →
可視化 の3ステップ • 数時間で 小さく始められる
©Fusic Co., Ltd. テレメトリーシグナルを取得して オブザーバビリティを始めよう まとめ • Traces — ボトルネック可視化
• Metrics — 改善効果の定量化 • Logs — 根本原因の特定
©Fusic Co., Ltd. OSEKKAI × TECHNOLOGY ご清聴いただきありがとうございました Thank You ココロと技術で、ぴったりも、びっくりも。
©Fusic Co., Ltd. Appendix 時間の関係で紹介しきれなかったスライドを供養するゾーンです
©Fusic Co., Ltd. Before/After — データに基づく改善効果
©Fusic Co., Ltd. N+1だけじゃない Traces で検出できるパターン • スパン数・形状・ギャップ が手がかり •
コードレビューで見逃すパターンを 発見