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
ActiveSupport::Notifications supporting instrum...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Y.Matsuda
November 08, 2024
Programming
1k
1
Share
ActiveSupport::Notifications supporting instrumentation of Rails apps with OpenTelemetry
Y.Matsuda
November 08, 2024
More Decks by Y.Matsuda
See All by Y.Matsuda
Accelerating the Feedback Loop of OpenTelemetry Instrumentation with otel-tui
ymtdzzz
1
700
Observability Technology Selection Tips
ymtdzzz
6
1.6k
Building Observability Infrastructure with OpenTelemetry and SaaS
ymtdzzz
2
1.5k
OpenTelemetryでRailsのパフォーマンス分析を始めてみよう(KoR2024)
ymtdzzz
5
5k
OIDC仕様に準拠した Makuake ID連携基盤構築の裏側
ymtdzzz
3
2.8k
Other Decks in Programming
See All in Programming
PHP で mp3 プレイヤーを実装しよう
m3m0r7
PRO
0
290
Oxlintとeslint-plugin-react-hooks 明日から始められそう?
t6adev
0
280
SREに優しいTerraform構成 modulesとstateの組み方
hiyanger
2
150
Kubernetes上でAgentを動かすための最新動向と押さえるべき概念まとめ
sotamaki0421
3
700
Vibe하게 만드는 Flutter GenUI App With ADK , 박제창, BWAI Incheon 2026
itsmedreamwalker
0
550
Lightning-Fast Method Calls with Ruby 4.1 ZJIT / RubyKaigi 2026
k0kubun
3
1.3k
ふりがな Deep Dive try! Swift Tokyo 2026
watura
0
240
レガシーPHP転生 〜父がドメインエキスパートだったのでDDD+Claude Codeでチート開発します〜
panda_program
0
1.1k
UIの境界線をデザインする | React Tokyo #15 メイントーク
sasagar
2
380
AIベース静的検査器の偽陽性率を抑える工夫3選
orgachem
PRO
4
360
CDK Deployのための ”反響定位”
watany
5
860
GoogleCloudとterraform完全に理解した
terisuke
1
160
Featured
See All Featured
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
240
Google's AI Overviews - The New Search
badams
0
990
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4k
Building a Modern Day E-commerce SEO Strategy
aleyda
45
9k
SEO for Brand Visibility & Recognition
aleyda
0
4.5k
Ethics towards AI in product and experience design
skipperchong
2
260
Fireside Chat
paigeccino
42
3.9k
A Modern Web Designer's Workflow
chriscoyier
698
190k
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
380
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
730
Transcript
@ymtdzzz OpenTelemetryによるRailsアプリの計装を 支えるActiveSupport::Notifications 2024.11.08 Fri.Kaigi on Rails 2024事後勉強会 @SmartHR
Yosuke MATSUDA (@ymtdzzz) 株式会社SmartHR プロダクトエンジニア 2
お久しぶりです&はじめまして 3 出典:モノリスでも使える! OpenTelemetryでRailsアプリのパフォーマンス分析を始めてみよう from Kaigi on Rails 2024
やっぱり今日も OpenTelemetry (トレース)
おさらい:トレースとは 5
6 トレース:追跡の単位(リクエストなど) おさらい:トレースとは
7 スパン:処理の単位 おさらい:トレースとは
8 トレースを出力すること:計装 • 自動計装: トレースを自動で出力させる(Gem毎に用 意) • 手動計装: トレースを手動で出力する
9 今日の話はこっち • 自動計装: トレースを自動で出力させる(Gem毎に用 意) • 手動計装: トレースを手動で出力する Railsの自動計装の仕組みはどうなって
いるのか?
10 OpenTelemetry:計装の技術標準 • 仕様(OpenTelemetry Specification) • 実装(言語別 SDK、計装ライブラリ) ※他にも色々ありますが、今回は割愛
計装のために利用する OpenTelemetryライブラリ 11
計装のために利用する OpenTelemetryライブラリ 12 普段私たちが使うのは 計装ライブラリ とRuby SDK
Ruby SDK?計装ライブラリ?
どちらも計装のためのライブラリ • Ruby SDK(opentelemetry-ruby) ◦ トレース設定(出力先やサービス名の設定など) ◦ 手動でスパンを出力したい場合に利用 • 計装ライブラリ
(opentelemetry-ruby-contrib/instrumentation) ◦ Gemに合わせたスパンを自動で出力してくれる ◦ たくさんあります(faraday, grape, mongo, pg, …) 14
どちらも計装のためのライブラリ • Ruby SDK(opentelemetry-ruby) ◦ トレース設定(出力先やサービス名の設定など) ◦ 手動でスパンを出力したい場合に利用 • 計装ライブラリ
(opentelemetry-ruby-contrib/instrumentation) ◦ Gemに合わせたスパンを自動で出力してくれる ◦ たくさんあります(faraday, grape, mongo, pg, …) 15 今日のテーマ
ところで:スパンを手動で生成したいケース 16 出典:Tuning GraphQL on Rails (p.37) from Kaigi on
Rails 2024
Railsの計装ライブラリを覗いてみよう
ここの話 18 自動でスパン(トレース) 出してやんよ!
ActionMailerの計装ライブラリ 19 https://github.com/open-telemetry/opentelemetry-ruby-contrib/ tree/main/instrumentation z
セットアップはこれだけ OpenTelemetry::SDK.configure do |c| # サービス名や出力先などの初期設定は省略 c.use 'OpenTelemetry::Instrumentation::ActionMailer' end 20
• これだけで勝手にスパンが出始める ◦ OpenTelemetry::SDK.configure ◦ ブロック内でConfigurator#use 何が起こっている?
前提知識: ActiveSupport::Notifications 21 • Rails内部のイベントを subscribe し、計測を行う仕組み • ActiveSupport::Notifications.sub scribeでRailsのイベントに
hookし て処理を走らせる 出典)Active Support Instrumentation で計測 - Railsガイド
処理を追ってみる (超スピードで)
まずはRailtieでconfigのinitialize直後にsubscribe 23 スパン生成用の Subscription Handlerでsubscribe Subscribeしたいイベント名 (今回は ActionMailer)
計装ライブラリの登録( Ruby SDK) 24 useで、指定した計装ライブラリを 配列にpush 計装ライブラリの installを呼び出し
ActionMailerの計装ライブラリの installを見てみる 25 イベントの payloadをスパンの attributeに詰める処理
計装ライブラリの独自 Subscription Handlerでイベントの開始と終了時に スパン生成処理を差し込む 26 Subscriberが読み込まれる流れについては時間の都合上省略 🙏 transform_payloadも最終的 にここで実行される( payloadの
Span Attributeへのセット) start, finishによりイベントの前 処理、後処理でスパンを生成す る
• Railsのイベントを ActiveSupport::Notificationsでsubscribe • 独自のSubscription Handlerを利用 ◦ イベントのstart, finishでスパンの生成とattributeセット •
Configuratorでuseしたinstrumentation libraryのinstall実行 ◦ hook時の処理(transform_payloadなど)を設定し有効化 Railsの計装ライブラリの実装ざっくりまとめ 27 Railsの仕組みに上手く乗っかっているこ とがわかりました!
モンキーパッチは使ってないの?
使っています(例: ActiveRecord) 29
モンキーパッチといえば …… 30 出典:現実のRuby/Railsアップグレード (p.33) from Kaigi on Rails 2024
Railsの計装ライブラリでもモンキーパッチをやめる動き 31 Github issue: opentelemetry-ruby-contrib #218
発端:ActionPackの計装ライブラリ 32 Github PR: opentelemetry-ruby-contrib #123 計装ライブラリのモンキーパッチが原因でリクエスト内容が意図せ ず書き換わってしまう問題
まとめ 33 • OpenTelemetryの計装で利用するライブラリ ◦ Ruby SDK:トレース設定、手動計装 ◦ 計装ライブラリ:Gem毎の自動計装 •
Railsの計装ライブラリ ◦ 多くはActiveSupport::Notificationsを利用 ◦ モンキーパッチも一部あるけど、危ないので ActiveSupport::Notificationsを利用する流れへ
ありがとうございました!
参考 35 • Ruby on Rails API • OpenTelemetry 公式ドキュメント
• Github - rails v7.2.2 • Github - opentelemetry-ruby • Github - opentelemetry-ruby-contrib ※スライド内に直接出典を記載したものを除く