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
1
24
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimization Driven by Telemetry Signals
PHPerKaigi2026
https://phperkaigi.jp/2026/
shiro seike
PRO
March 20, 2026
Tweet
Share
More Decks by shiro seike
See All by shiro seike
歴史から学ぶ「Why PHP?」 PHPを書く理由を改めて理解する / Learning from History: “Why PHP?” Rediscovering the Reasons for Writing PHP
seike460
PRO
0
380
Team-First Serverless Platform Engineering Approach to PHP Applications with Laravel and Bref
seike460
PRO
0
63
なぜ適用するか、移行して理解するClean Architecture 〜構造を超えて設計を継承する〜 / Why Apply, Migrate and Understand Clean Architecture - Inherit Design Beyond Structure
seike460
PRO
3
1k
生成AIコーディングとの向き合い方、AIと共創するという考え方 / How to deal with generative AI coding and the concept of co-creating with AI
seike460
PRO
1
490
地方のPHPerもクラウドを使う理由 ~コストの最適化とチームに向き合う~ / Why even local PHPers use the cloud ~optimize costs and face the team
seike460
PRO
0
100
OpenTelemetryで始めるベンダーフリーなobservability / Vendor-free observability starting with OpenTelemetry
seike460
PRO
0
250
AIコーディングの本質は“コード“ではなく“構造“だった / The essence of AI coding is not “code” but "structure
seike460
PRO
2
1.4k
OpenTelemetryを活用したObservability入門 / Introduction to Observability with OpenTelemetry
seike460
PRO
2
1.1k
Amazon Q Developer Proで効率化するAPI開発入門
seike460
PRO
0
520
Other Decks in Programming
See All in Programming
20260228_JAWS_Beginner_Kansai
takuyay0ne
5
570
CDIの誤解しがちな仕様とその対処TIPS
futokiyo
0
220
守る「だけ」の優しいEMを抜けて、 事業とチームを両方見る視点を身につけた話
maroon8021
3
1k
Windows on Ryzen and I
seosoft
0
310
OTP を自動で入力する裏技
megabitsenmzq
0
110
Codex の「自走力」を高める
yorifuji
0
1.2k
Agent Skills Workshop - AIへの頼み方を仕組み化する
gotalab555
15
8.9k
PostgreSQL を使った快適な go test 環境を求めて
otakakot
0
560
最初からAWS CDKで技術検証してもいいんじゃない?
akihisaikeda
4
160
AI駆動開発の本音 〜Claude Code並列開発で見えたエンジニアの新しい役割〜
hisuzuya
4
520
Docコメントで始める簡単ガードレール
keisukeikeda
1
120
ポーリング処理廃止によるイベント駆動アーキテクチャへの移行
seitarof
3
1.1k
Featured
See All Featured
Site-Speed That Sticks
csswizardry
13
1.1k
Google's AI Overviews - The New Search
badams
0
930
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
640
Designing Powerful Visuals for Engaging Learning
tmiket
0
280
KATA
mclloyd
PRO
35
15k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
200
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
290
Fireside Chat
paigeccino
42
3.8k
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
180
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
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 で検出できるパターン • スパン数・形状・ギャップ が手がかり •
コードレビューで見逃すパターンを 発見