• /
  • EnglishEspañolFrançais日本語한국어Português
  • ログイン今すぐ開始

Ruby agent release notesRSS

April 16
Ruby agent v10.4.0

重要

We recommend updating to the latest agent version as soon as it's available. If you can't upgrade to the latest version, update your agents to a version no more than 90 days old. Read more about keeping agents up to date.

See the New Relic Ruby agent EOL policy for information about agent releases and support dates.

v10.4.0

  • Feature: Add Rails.event instrumentation for structured logging

    The agent now supports Rails.event as structured log events. When enabled, events published via Rails.event.notify are captured and forwarded to New Relic as log events. Event payloads, tags, context, timestamps, and source locations are automatically captured as log attributes.

    This instrumentation can be configured with the following options:

    • instrumentation.rails_event_logger - Controls whether Rails.event instrumentation is enabled. Defaults to use the value of application_logging.enabled.
    • instrumentation.rails_event_logger.event_names - An array of specific event names to capture. When empty (default), all Rails.event notifications are captured. Use this to filter events by name, for example: ['user.signup', 'payment.processed'].

    PR#3526

  • Feature: Add instrumentation for Rails Active Job Continuations

    The agent now instruments Rails Active Job Continuations, providing visibility into individual step execution within long-running jobs. Step names are included in segment metrics (e.g., Ruby/ActiveJob/default/MyJob/step/process_records) and step-specific attributes like cursor position, resumed status, and interrupted status are captured. A new configuration option, disable_active_job_step_names, allows users to exclude step names from metric names to reduce metric cardinality if needed (defaults to false). PR#3493

  • Feature: Add sidekiq.separate_transactions configuration option

    A new configuration option, sidekiq.separate_transactions, allows Sidekiq jobs executed during a web transaction to run in their own separate transaction. When enabled, this prevents Sidekiq job execution time from being included in web transaction metrics, providing more accurate performance data. The feature is opt-in (default: false) to maintain backward compatibility. This only affects jobs executed during active web transactions; jobs starting independently or nested within other background jobs are unaffected. Issue#3364 PR#3514

  • Bugfix: Update regexes that may have been vulnerable to ReDOS attacks

    Previously, the agent had a few regexes identified as possible targets for polynomial time complexity (ReDOS) attacks. Those regexes are now updated to address the concerns. PR#3520

  • Bugfix: Prevent crashes during HTTPX segment creation

    Previously, if start_external_request_segment encountered an error and returned nil, the agent would trigger a NoMethodError when attempting to add headers to the missing segment. We've added a guard check to ensure the instrumentation handles these cases gracefully.

    Bravo to @thebravoman for the report! Issue#3509 PR#3510

  • Bugfix: Make Transaction#finish idempotent

    Previously, if the Transaction#finish method was called multiple times, more than one transaction could be created for the same operation. Now, a mutex protects calls to Transaction#finish to make sure finish operations only run once. PR#3513

  • Bugfix: Log deprecation warning for Datastores.wrap API once

    Previously, this warning was being logged on every call to Datastores.wrap. Now, it will be logged only on the first call. In addition, the documentation has been updated to note the deprecated status of the second and third callback arguments. Issue#3516 PR#3519

April 9
Ruby agent v10.3.0

重要

最新のエージェント バージョンが利用可能になったらすぐに更新することをお勧めします。最新バージョンにアップグレードできない場合は、エージェントを 90 日以内のバージョンに更新してください。エージェントを最新の状態に保つ方法の詳細については、こちらをご覧ください。

エージェントのリリースとサポート日については、New Relic Ruby エージェントのEOL ポリシーを参照してください。

v10.3.0

  • 機能:SQLコメントによるデータベースクエリ命名機能を追加

    データベースクエリにSQLコメントを使用して明示的に名前を付けることができるようになりました。クエリには、追跡と識別を容易にするために安定した名前を割り当てるための/* NewRelicQueryName: CustomName */コメントを含めることができます。これは、パフォーマンス低下やインシデント発生時に特定のデータベースクエリを追跡する際に特に役立ちます。PR#3480

  • 機能: セマンティックロガー計装を追加

    エージェントは、 semantic_logger gem バージョン 4.6.0 以降のセマンティック ロガーログ転送と装飾をサポートするようになりました。 以前 Semantic ロガーの組み込みNew Relicアペンダーを使用していた場合は、重複ログの送信を避けるために、いずれかの方法を選択することをお勧めします。 New Relicのセマンティック ロガー計装は、 instrumentation.semantic_loggerdisabledに設定することで無効にできます。 PR#3467

    この計装を形作る上で貴重なフィードバックを提供してくれた@jdelStrotherに感謝します。

  • 機能: 新しい「ignored_middleware_classes」設定を追加

    新しい設定オプションignored_middleware_classes使用すると、ユーザーは特定のミドルウェアを計装から除外できます。 ラック::Cors)。デフォルトでは空の配列になります。問題番号1814 PR番号3481

  • 機能: 新しいNewRelic::Agent.add_transaction_log_attributes API を追加

    新しいAPI NewRelic::Agent.add_transaction_log_attributes使用すると、ユーザーは、現在の場所のログイベントに、瞬間スコープのカスタムアトリビュートを追加できます。 これらの属性は、現在のトランザクションの範囲内で作成されたログにのみ適用されます。PR#3472

  • バグ修正:ActionCableブロードキャストメトリクスのカーディナリティを削減するための設定オプションを提供

    デフォルトでは、Metrix for ActionCable ブロードキャスト メソッド呼び出しにはブロードキャストの値が含まれます。 この値は非常に高いカーディナリティを持つ可能性があります。 現在、 :simplify_action_cable_broadcast_metrics設定オプションにより、ユーザーはメトリクス名からブロードキャスト値を削除できるようになりました。 これにより、 Ruby/ActionCable/broadcastのようなメトリクスが作成されます。 この設定オプションを有効にすると、ブロードキャスト値がスパン属性として追加されます。PR#3463

  • バグ修正: FIPS/FedRAMP準拠のための不要な「digest/md5」要件を削除

    エージェントのバージョン7.1.0では、FIPS準拠のためMD5の使用がSHA1に置き換えられました(PR) 。しかし、以前の「digest/md5」の要件は削除されませんでした。FIPS/FedRAMP の支援に関する要件を削除しました。 この件を指摘してくださった@ashleyboehsさんに感謝いたします!Issue#3469 PR#3470

  • バグ修正: シャットダウン遅延を回避するため、 rails testの間にエージェントが起動しないようにする

    以前は、エージェントがrails testコマンドを実行すると、約3秒のシャットダウン遅延が発生していました。Railsのテスト実行中にエージェントが起動しないようにするため、定数Rails::Command::TestCommandがデフォルトのautostart.denylisted_constantsリストに追加されました。この件を指摘してくださった@varyformさんに感謝します。PR#3478

  • バグ修正: Falcon Web サーバーを使用する場合の「経過時間を計算できません」という警告を修正

    エージェントは、 Falconで実行するときにThread.current.object_idの代わりにFiber.current.object_id使用して状態を追跡するようになり、同じスレッドを共有する同時requestsによる衝突を防ぎます。 また、Falcon使用時に発生する「NameError: uninitilized constant Async::HTTP::VERSION 」というエラーも修正します。この件を指摘してくださった@97jazさん@gsarさんに感謝します。PR#3483

  • バグ修正: harvest.rb のタイプミスにより NoMethodError が発生する問題を修正しました。

    lib/new_relic/agent/agent_helpers/harvest.rbタイプミスによりNoMethodError: undefined method 'agent' for NewRelic:Moduleが発生しました。この問題を報告してくれた@oakbowに感謝します。PR#3484

  • バグ修正: 非推奨の ObjectSpace._id2ref の使用を削除

    エージェントは、非推奨のObjectSpace._id2refメソッドの代わりに別の方法を使用するようになり、Ruby 4.0 以降で実行する場合の非推奨警告が解消されます。PR#3490

  • バグ修正: ロギング計装の NoMethoError を修正

    以前は、Logging gem 計装がローカル ログを装飾しようとしたときに、文字列以外のオブジェクトに遭遇するとNoMethodErrorが発生していました。 この問題は修正されました。PR#3501

February 18
Ruby agent v10.2.0

重要

最新のエージェント バージョンが利用可能になったらすぐに更新することをお勧めします。最新バージョンにアップグレードできない場合は、エージェントを 90 日以内のバージョンに更新してください。エージェントを最新の状態に保つ方法の詳細については、こちらをご覧ください。

エージェントのリリースとサポート日については、New Relic Ruby エージェントのEOL ポリシーを参照してください。

v10.2.0

  • 機能: OpenTelemetry トレースのサポートのためのハイブリッド エージェントの導入

    New Relic Rubyエージェントの新しいハイブリッドエージェント機能を使用して、 OpenTelemetry Tracing APIをNew Relicテレメトリーに変換できるようになりました。 これにより、 newrelic_rpm gem はOpenTelemetry SDK と同様に動作し、 OpenTelemetry APIコールを受け入れて、使い慣れた属性と名前を持つNew Relicトランザクションとセグメントに変換できるようになります。

    次の設定オプションは、ハイブリッド エージェント機能に関連しています。

    設定名デフォルト行動
    OpenTelemetryが有効falseNew Relicを介して送信されるすべてのOpenTelemetry信号を無効にするグローバル設定オプション。
    OpenTelemetry.Trace.enabledtrueOpenTelemetryスパンからの瞬間トレース セグメントとタイムスライス メトリクスの作成を有効にします
    OpenTelemetry.トレース.include''OpenTelemetryのカンマ区切りのリスト。文字列として表されます(例: 「AppTracer1, OpenTelemetry ::計装::Bunny::計装」)、トレース信号がNew Relicに送信されます
    OpenTelemetry.トレース.exclude''OpenTelemetryのカンマ区切りのリスト。文字列として表されます(例: "AppTracer1, OpenTelemetry ::計装::Bunny::計装")、トレース信号はNew Relicに送信されません。 New Relic計装と競合する計装用の既知のトレーサーはすべてデフォルトで除外されます。
  • 機能: 設定オプション error_collector.backtrace_truncate_location を追加

    新しい設定オプションerror_collector.backtrace_truncate_locationが追加されました。これにより、フレーム数がerror_collector.max_backtrace_framesを超えた場合にバックトレース内のどこで切り捨てるかをユーザーが指定できるようになりました。 オプションは、 'top' (先頭からフレームを削除)、 'middle' (先頭と末尾を保持したまま中間からフレームを削除)、または'end' (末尾からフレームを削除) です。デフォルトは'middle'です。PR#3424

  • 機能: Logging gem 計装を追加

    エージェントは、 Logging gemによって生成されたログを記録するようになりました。PR#3420

  • 機能: 設定オプション utilization.detect_in_parallel を追加

    新しい設定オプションutilization.detect_in_parallelが追加されました。これは、エージェントの起動を高速化するためにcloudベンダー情報を検出するときにエージェントがスレッドを使用するかどうかを制御します。 falseに設定すると、ベンダー検出はスレッドを作成せずに順番に実行されます。デフォルトはtrueです。PR#3439

February 3
Ruby agent v10.1.0

重要

We recommend updating to the latest agent version as soon as it's available. If you can't upgrade to the latest version, update your agents to a version no more than 90 days old. Read more about keeping agents up to date.

See the New Relic Ruby agent EOL policy for information about agent releases and support dates.

v10.1.0

  • Feature: Add support for forking processes in Parallel gem instrumentation

    Parallel gem instrumentation has been added to allow more consistent monitoring in processes forked using the Parallel gem. PR#3405

  • Feature: Add support for Grape v3.1.0

    Grape's release of v3.1.0 introduced changes that were incompatible with the agent's instrumentation, causing issues when collecting transaction names. The agent has been updated to properly extract class names for transaction naming in the updated Grape API structure. PR#3413

  • Bugfix: Create health check files in forked processes

    The agent now properly initializes health check loops after forking, ensuring each process generates its own health check file. This fix also has the effect of correctly including entity.guid values in the health check files. PR#3409 Issue#3408

  • Bugfix: Fix sidekiq.ignore_retry_errors

    The configuration option sidekiq.ignore_retry_errors: true was continuing to report retry errors. The agent now correctly ignores retry errors and only reports when jobs permanently fail. PR#3399

January 14
Ruby agent v10.0.0

重要

メジャー バージョン アップデート:このバージョンの Ruby エージェントは SemVer メジャー アップデートであり、重大な変更が含まれています。メジャー バージョンでは、メンテナーの規定によりサポート終了となった言語ランタイムのサポートが廃止されることがあります。さらに、メジャー バージョンでは、特定の計装のサポートが終了し、削除される場合があります。 これらの変更の詳細については、ここにある移行ガイドを参照してください。

重要

最新のエージェント バージョンが利用可能になったらすぐに更新することをお勧めします。最新バージョンにアップグレードできない場合は、エージェントを 90 日以内のバージョンに更新してください。エージェントを最新の状態に保つ方法の詳細については、こちらをご覧ください。

エージェントのリリースとサポート日については、New Relic Ruby エージェントのEOL ポリシーを参照してください。

v10.0.0

  • 重大な変更: Ruby 2.4 および 2.5 のサポートを削除

    Ruby バージョン 2.4 および 2.5 のサポートは削除されました。新しい最低限必要な Ruby バージョンは 2.6 になりました。PR#3314

  • 重大な変更: クロスアプリケーショントレース (CAT) の削除

    以前は、クロスアプリケーション トレーシング (CAT) が非推奨となり、ディストリビューティッド(分散)トレーシングが使用されました。 CAT 機能は削除されました。設定オプションcross_application_tracer.enabledは削除されました。 パブリック API メソッドNewRelic::Agent::External.process_request_metadataNewRelic::Agent::External.get_response_metadataNewRelic::Agent::Transaction::ExternalRequestSegment#process_response_metadataNewRelic::Agent::Transaction::ExternalRequestSegment#get_request_metadata 、およびNewRelic::Agent::Transaction::ExternalRequestSegment#read_response_headersも削除されました。PR#3333

  • 重大な変更: ActiveJob メトリクスとセグメントの名前を変更する

    ActiveJob メトリクスが更新され、より具体的なレポートを作成するためにジョブのクラス名が含まれるようになりました。 これは重大な変更であり、カスタムダッシュボードまたはアラートの更新が必要になる場合があります。 PR#3370 PR#3320

    • 古い形式: Ruby/ActiveJob/<QueueName>/<Method>
    • 新しいフォーマット: Ruby/ActiveJob/<QueueName>/<ClassName>/<Method>

    さらに、アクティブ ジョブのキュー登録アクション用に作成されたセグメントにジョブ クラスが含まれるようになりました。

    • 古い形式: ActiveJob/<QueueAdapter>/Queue/<Event>/Named/<QueueName>
    • 新しいフォーマット: ActiveJob/<QueueAdapter>/Queue/<Event>/Named/<QueueName>/<ClassName>
  • 変更点: bin/newrelicコマンドの名前を次のように変更します bin/newrelic_rpm

    エージェントの CLI の実行可能ファイルの名前がbin/newrelicからbin/newrelic_rpmに変更されました。この変更により、スタンドアロンの New Relic CLI ツールとの名前の競合が解決されます。PR#3323

  • 変更点: newrelic deployments CLI コマンドを削除します

    非推奨のnewrelic deployments CLI コマンドは削除されました。New Relicの変更とデプロイメントを追跡するには、利用可能なオプションのリストについては、変更追跡 (変更追跡機能)のガイドを参照してください。 PR#3299

  • 重大な変更: NewRelic::エージェント::SqlSampler#notice_sql メソッドを削除

    代わりに、ユーザーはNewRelic::Agent::Datastores.notice_sqlを呼び出す必要があります。PR#3338

  • 重大な変更: さまざまな NewRelic::エージェント::Datastores API から未使用の引数を削除

    NewRelic::Agent::Datastoresクラスの次の API からメソッド引数が削除されました:

    • NewRelic::Agent::Datastores.notice_sqlには、以前は 3 つの位置引数queryscoped_metricelapsedがありました。現在はqueryのみになっています。
    • NewRelic::Agent::Datastores.notice_statement、以前は 2 つの位置引数queryelapsedがありました。現在はqueryのみになっています。
    • NewRelic::Agent::Datastores.wrap プロセスが必要です。以前は、プロシージャは、yield の結果、最も具体的なスコープのメトリック名、および呼び出しの経過時間という 3 つの引数を受け取りました。 今では、yield の結果のみを受け取ります。

    削除された引数の値は、呼び出し時の現在のセグメントから導出されます。PR#3347

  • 重大な変更: 実験的機能の設定可能なセキュリティ ポリシー (CSP) を削除します。

    実験的機能である設定可能なセキュリティ ポリシー (CSP) はサポートされなくなり、削除されました。 PR#3292

  • 重大な変更: Puma バージョン '<' 3.9.0 のサポートを削除します

    現在サポートされている Puma の最小バージョンは 3.9.0 以上です。PR#3326

  • 重大な変更: 設定の検証と強制実行の改善

    係数設定に提供された値を強制および検証するために使用される内部機能は、よりパフォーマンスが向上し、より正確になりました。

    • nil がサポートされていない設定の設定値として指定された場合、警告メッセージが newrelic_agent.log ファイルに記録されるようになりました。
    • フロート設定タイプには整数値が許可されます
    • フロート値は整数設定型で許可されます
    • 無効な入力値を置き換えるデフォルト値が見つかると、致命的な中断が防止されますPR#3341
  • 重大な変更: ディストリビューティッド(分散)トレーシング リモート親サンプラーの「default」オプションを「adaptive」に置き換えます。

    以前は、 distributed_tracing.sampler.remote_parent_sampleddistributed_tracing.sampler.remote_parent_not_sampledデフォルト オプションはdefaultであり、既存のアダプティブ サンプラーが使用されていました。defaultオプションの名前がadaptiveに変更されました。PR#3363

  • 機能: logger依存関係として追加

    継続的なログ機能と Ruby 4.0.0 以降のバージョンのサポートを確保するために、 logger gem がエージェントの依存関係としてリストされるようになりました。PR#3293

  • 機能: Active Support 通知許可リストの設定オプションを追加

    新しい設定オプションinstrumentation.active_support_notifications.active_support_events使用すると、ユーザーはエージェントが購読するアクティブ サポート通知イベント名の許可リストを定義できます。 デフォルトでは、エージェントはすべてのActive Support: CachingおよびActive Support: Messagesイベントをサブスクライブします。PR#3327

  • 機能: Ruby の組み込み Gzip 圧縮を使用する

    エージェントは、以前のカスタム実装に代わって、Ruby 標準ライブラリの組み込みZlib.gzipメソッドを圧縮に使用するようになりました。PR#3332

  • 機能: NewRelic::Agent#record_custom_event API の引数検証を追加

    無効なevent_typeが指定された場合、 NewRelic::Agent#record_custom_event API はArgumentErrorを発生させるようになりました。有効なイベント タイプは、英数字、アンダースコア (_)、コロン (:)、またはスペース ( ) のみで構成されている必要があります。PR#3319

  • 機能: ルートサンプリング設定オプションを追加

    distributed_tracing.sampler.rootを使用して、現在のサービス内で生成されたトレースのサンプリング動作を構成できるようになりました。PR#3330

    利用できるモードは 4 つあります。

    モード説明
    adaptive既存の適応サンプラーアルゴリズムを使用する
    always_offルートトレースの0%をサンプリング済みとしてマークします
    always_onルートトレースの100%をサンプリング済みとしてマークします
    trace_id_ratio_baseddistributed_tracing.sampler.root.trace_id_ratio_based.ratioに設定された比率に基づいてトレースをサンプリングします。比率は 0.0 ~ 1.0 のフロートでなければなりません
  • 機能: トレース ID 比率ベースのサンプリング オプションを追加

    エージェントは、 OpenTelemetry ID Ratio Based サンプラー アルゴリズムを使用してトレースをサンプリングできるようになりました。 PR#3330トレース ID に基づいて 0.0 ~ 1.0 の確率でトレースをサンプリングします。

    このオプションを使用するには、まずディストリビューティッド(分散)トレーシング サンプラー設定をtrace_id_ratio_basedに設定し、次に対応するdistributed_tracing.sampler.*.trace_id_ratio_based.ratioサンプラーを 0.0 ~ 1.0 のフロートに設定する必要があります。

    例えば:

    distributed_tracing.sampler.remote_parent_sampled: 'trace_id_ratio_based'
    distributed_tracing.sampler.remote_parent_sampled.trace_id_ratio_based.ratio': 0.5

    この設定では、リモートの親がサンプリングされるすべてのトレースについて、トレースの約 50% がサンプリングされます。

    このオプションは以下で利用可能です:

    • distributed_tracing.sampler.root
    • distributed_tracing.sampler.remote_parent_sampled
    • distributed_tracing.sampler.remote_parent_not_sampled
  • 機能: エンティティ GUID をAgent Controlヘルス チェック ファイルに追加します

    Agent Control環境内でエージェントが開始されると、各プロセスの構成されたファイルの場所にヘルス チェック ファイルが作成されます。 このファイルには、利用可能な場合、エージェントに関連するエンティティの GUID が含まれるようになりました。PR#3371

  • バグ修正: GCP 使用率検出におけるNoMethodErrorを解決しました。

    GCP メタデータ検出ロジックは、 nilまたは予期しない値を適切に処理し、サービス初期化のクラッシュを防ぐようになりました。PR#3388

December 2, 2025
Ruby agent v9.24.0

重要

最新のエージェント バージョンが利用可能になったらすぐに更新することをお勧めします。最新バージョンにアップグレードできない場合は、エージェントを 90 日以内のバージョンに更新してください。エージェントを最新の状態に保つ方法の詳細については、こちらをご覧ください。

エージェントのリリースとサポート日については、New Relic Ruby エージェントのEOL ポリシーを参照してください。

バージョン9.24.0

  • 機能: SqlSampler#notice_sql API の廃止に関するお知らせ

    NewRelic::Agent::SqlSampler#notice_sqlメソッドは非推奨であり、将来のメジャー バージョンで削除される予定です。代わりに、ユーザーはNewRelic::Agent::Datastores.notice_sqlを呼び出す必要があります。PR#3345

  • 機能: Datastores.notice_sql の 2 番目と 3 番目の引数の非推奨通知API

    NewRelic::Agent::Datastores.notice_sqlメソッドの 2 番目 (scoped_metric) および 3 番目 (elapsed) の引数は非推奨です。それらはしばらくの間、この方法では使用されていません。代わりに、これらの値は、API が呼び出されたときに現在のセグメントに基づいて設定されます。PR#3345

  • 機能: Datastores.notice_statement の 2 番目の引数の非推奨通知API

    NewRelic::Agent::Datastores.notice_statementメソッドの 2 番目の引数 (elapsed) は非推奨です。この方法は、しばらくの間使用されていません。代わりに、この値は API が呼び出されたときに現在のセグメントに基づいて設定されます。PR#3346

  • 機能: Datastores.wrap API の proc の 2 番目と 3 番目の引数の非推奨通知

    NewRelic::Agent::Datastores.wrapメソッドは変更されています。将来のメジャー バージョンでは、proc は単一の引数 (yield の結果) のみを受け入れるようになります。スコープ付きメトリック名と経過引数は、 Datastores.notice_sqlメソッドから削除されるため削除されます。 スコープ付きメトリック名と経過値は、ラップが実行されるときに現在のセグメントから導出されます。 PR#3346

Copyright © 2026 New Relic株式会社。

This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.