|
| 1 | +--- |
| 2 | +title: 計装ライブラリの使用 |
| 3 | +linkTitle: ライブラリ |
| 4 | +aliases: [configuring_automatic_instrumentation, automatic] |
| 5 | +weight: 30 |
| 6 | +default_lang_commit: 6a865f53d8e40c17f42772fb8fb100d62a61fb7e |
| 7 | +cSpell:ignore: faraday metapackage sinatra |
| 8 | +--- |
| 9 | + |
| 10 | +{{% docs/languages/libraries-intro ruby %}} |
| 11 | + |
| 12 | +## 計装ライブラリの使用 {#use-instrumentation-libraries} |
| 13 | + |
| 14 | +ライブラリにOpenTelemetryが組み込まれていない場合は、[計装ライブラリ](/docs/specs/otel/glossary/#instrumentation-library)を使用して、ライブラリやフレームワークのテレメトリーデータを生成できます。 |
| 15 | + |
| 16 | +たとえば、Railsを使用していて、[`opentelemetry-instrumentation-rails`](https://rubygems.org/gems/opentelemetry-instrumentation-rails/)を有効にしている場合、実行中のRailsアプリはコントーラーへの受信リクエストのテレメトリーデータを自動的に生成します。 |
| 17 | + |
| 18 | +### すべての計装ライブラリの構成 {#configuring-all-instrumentation-libraries} |
| 19 | + |
| 20 | +OpenTelemetry Rubyは、Rubyベースのすべての計装ライブラリを単一のパッケージにバンドルしたメタパッケージである [`opentelemetry-instrumentation-all`](https://rubygems.org/gems/opentelemetry-instrumentation-all) を提供します。 |
| 21 | +最小限の労力で、すべてのライブラリのテレメトリーを追加するための便利な方法です。 |
| 22 | + |
| 23 | +```sh |
| 24 | +gem 'opentelemetry-sdk' |
| 25 | +gem 'opentelemetry-exporter-otlp' |
| 26 | +gem 'opentelemetry-instrumentation-all' |
| 27 | +``` |
| 28 | + |
| 29 | +アプリケーションライフサイクルの早いタイミングで構成します。 |
| 30 | +Railsのイニシャライザーを使用した下記の例を参照してください。 |
| 31 | + |
| 32 | +```ruby |
| 33 | +# config/initializers/opentelemetry.rb |
| 34 | +require 'opentelemetry/sdk' |
| 35 | +require 'opentelemetry/exporter/otlp' |
| 36 | +require 'opentelemetry/instrumentation/all' |
| 37 | +OpenTelemetry::SDK.configure do |c| |
| 38 | + c.service_name = '<YOUR_SERVICE_NAME>' |
| 39 | + c.use_all() # すべての計装を有効化します! |
| 40 | +end |
| 41 | +``` |
| 42 | + |
| 43 | +このコードにより、すべての計装ライブラリがインストールされ、アプリで使用しているライブラリに一致するものが有効になります。 |
| 44 | + |
| 45 | +### 特定の計装ライブラリの構成を上書きする {#overriding-configuration-for-specific-instrumentation-libraries} |
| 46 | + |
| 47 | +すべての計装ライブラリを有効化しつつ、特定の計装ライブラリの構成を上書きしたい場合は、構成マップパラメーターを使用して `use_all` を呼び出します。 |
| 48 | +キーはライブラリを表し、値はその特定の構成パラメーターです。 |
| 49 | + |
| 50 | +たとえば、`Redis` 計装を _除く_ すべての計装をアプリにインストールする方法は次のとおりです。 |
| 51 | + |
| 52 | +```ruby |
| 53 | +require 'opentelemetry/sdk' |
| 54 | +require 'opentelemetry/instrumentation/all' |
| 55 | + |
| 56 | +OpenTelemetry::SDK.configure do |c| |
| 57 | + config = {'OpenTelemetry::Instrumentation::Redis' => { enabled: false }} |
| 58 | + c.use_all(config) |
| 59 | +end |
| 60 | +``` |
| 61 | + |
| 62 | +さらに多くの計装を上書きするには、`config` マップに別のエントリを追加します。 |
| 63 | + |
| 64 | +#### 環境変数を使用して特定の計装ライブラリの構成を上書きする {#overriding-configuration-for-specific-instrumentation-libraries-with-environment-variables} |
| 65 | + |
| 66 | +環境変数を使用して、特定の計装ライブラリを無効化することもできます。 |
| 67 | +環境変数によって無効化された計装は、ローカル構成よりも優先されます。 |
| 68 | +環境変数の命名規則は、ライブラリ名を大文字にして `::` をアンダースコアに置き換え、`OPENTELEMETRY` を `OTEL_LANG` に短縮し、最後に `_ENABLED` を追加したものです。 |
| 69 | + |
| 70 | +たとえば、`OpenTelemetry::Instrumentation::Sinatra` の環境変数名は `OTEL_RUBY_INSTRUMENTATION_SINATRA_ENABLED` です。 |
| 71 | + |
| 72 | +```bash |
| 73 | +export OTEL_RUBY_INSTRUMENTATION_SINATRA_ENABLED=false |
| 74 | +``` |
| 75 | + |
| 76 | +### 特定の計装ライブラリの構成 {#configuring-specific-instrumentation-libraries} |
| 77 | + |
| 78 | +より選択的に特定の計装ライブラリのみをインストールして使用することもできます。 |
| 79 | +たとえば、`Sinatra` と `Faraday` のみを使用し、`Faraday` に追加の構成パラメーターを設定する方法は次のとおりです。 |
| 80 | + |
| 81 | +はじめに、使用したい特定の計装ライブラリをインストールします。 |
| 82 | + |
| 83 | +```sh |
| 84 | +gem install opentelemetry-instrumentation-sinatra |
| 85 | +gem install opentelemetry-instrumentation-faraday |
| 86 | +``` |
| 87 | + |
| 88 | +次に、それらを構成します。 |
| 89 | + |
| 90 | +```ruby |
| 91 | +require 'opentelemetry/sdk' |
| 92 | + |
| 93 | +# デフォルト構成で、互換性のあるすべての計装をインストールします |
| 94 | +OpenTelemetry::SDK.configure do |c| |
| 95 | + c.use 'OpenTelemetry::Instrumentation::Sinatra' |
| 96 | + c.use 'OpenTelemetry::Instrumentation::Faraday', { opt: 'value' } |
| 97 | +end |
| 98 | +``` |
| 99 | + |
| 100 | +#### 環境変数を使用して特定の計装ライブラリを構成する {#configuring-specific-instrumentation-libraries-with-environment-variables} |
| 101 | + |
| 102 | +環境変数を使用して、特定の計装ライブラリのオプションを定義することもできます。 |
| 103 | +例によって、環境変数は計装の名前を大文字にして `::` をアンダースコアに置き換え、`OPENTELEMETRY` を `OTEL_{LANG}` に短縮し、最後に `_CONFIG_OPTS` を追加したものです。 |
| 104 | + |
| 105 | +たとえば、`OpenTelemetry::Instrumentation::Faraday` の環境変数名は `OTEL_RUBY_INSTRUMENTATION_FARADAY_CONFIG_OPTS` です。 |
| 106 | +A value of |
| 107 | +`peer_service=new_service;span_kind=client` は、[前のセクション](#configuring-specific-instrumentation-libraries)でFaradayに設定されたオプションを上書きします。 |
| 108 | + |
| 109 | +```bash |
| 110 | +export OTEL_RUBY_INSTRUMENTATION_FARADAY_CONFIG_OPTS="peer_service=new_service;span_kind=client" |
| 111 | +``` |
| 112 | + |
| 113 | +次の表は、オプションのデータ型に応じた許容される値の形式を示しています。 |
| 114 | + |
| 115 | +| Data Type | Value | Example | |
| 116 | +| --------- | ------------------ | ---------------- | |
| 117 | +| Array | `,` 区切りの文字列 | `option=a,b,c,d` | |
| 118 | +| Boolean | true/false | `option=true` | |
| 119 | +| Integer | 文字列 | `option=string` | |
| 120 | +| String | 文字列 | `option=string` | |
| 121 | +| Enum | 文字列 | `option=string` | |
| 122 | +| Callable | 許容されない | N\A | |
| 123 | + |
| 124 | +### 次のステップ {#next-steps} |
| 125 | + |
| 126 | +計装ライブラリは、Rubyアプリに関する多くの有用なテレメトリーデータを生成する最も簡単な方法です。 |
| 127 | +しかし、アプリケーションロジック特有のデータは生成しません。 |
| 128 | +そのためには、[計装コード](../instrumentation)を使用して、計装ライブラリからの計装を強化する必要があります。 |
0 commit comments