互換性要件
サポートされている .NET Core のランタイム
.NET Tracer は、.NET Core 3.1、.NET 5、.NET 6、.NET 7、.NET 8、.NET 9 でのインスツルメンテーションをサポートします。
Datadog の .NET Core ライブラリとプロセッサアーキテクチャーのサポート一覧 (レガシーバージョンとメンテナンスバージョンを含む) については、互換性要件を参照してください。
インストールと利用開始
AWS Lambda や Azure Functions などのサーバーレス環境で Datadog APM を設定するには、
サーバーレスを参照してください。
注: Datadog の自動インスツルメンテーションは .NET CLR Profiling API に依存します。この API で許可されるサブスクライバーは 1 つのみです (例: Datadog APM)。可視性を最大化するため、アプリケーション環境では 1 つの APM ソリューションだけを実行してください。
インストール
作業を始める前に、Agent のインストールと構成が済んでいることを確認してください。
- トレーサーをインストールします。
- Enable the tracer for your service.
- ライブデータを表示します。
トレーサーをインストールする
Datadog Agent をインストールして構成したら、次はアプリケーションに直接トレーシングライブラリを追加してインスツルメントします。互換性情報の詳細をお読みください。
Datadog .NET Tracer は、マシン上のすべてのサービスがインスツルメントされるようにマシン全体にインストールすることも、アプリケーションごとにインストールすることも可能で、開発者はアプリケーションの依存関係を通じてインスツルメンテーションを管理することができます。マシン全体のインストール手順を見るには、Windows または Linux タブをクリックします。アプリケーションごとのインストール手順を見るには、NuGet タブをクリックします。
.NET Tracer をマシン全体にインストールするには
.NET Tracer MSI インストーラーをダウンロードします。64 ビット版の Windows を実行している場合は、x64 MSI インストーラーを使用してください。32 ビット版の Windows を実行している場合のみ、x86 インストーラーを選択します。v3.0.0 からは、32 ビットのオペレーティングシステムがサポート対象外となるため、x64 インストーラーのみが提供されます。
管理者権限で .NET トレーサー MSI インストーラーを実行します。
PowerShell で次を実行することで、MSI セットアップをスクリプト化することもできます: Start-Process -Wait msiexec -ArgumentList '/qn /i datadog-apm.msi'
.NET Tracer をマシン全体にインストールするには
お使いの OS とアーキテクチャに対応した最新の .NET Tracer パッケージをダウンロードします。
以下のコマンドのいずれかを実行して、パッケージをインストールし、適切な権限で .NET トレーサーのログディレクトリ /var/log/datadog/dotnet
を作成します。
- Debian または Ubuntu
sudo dpkg -i ./datadog-dotnet-apm_<TRACER_VERSION>_amd64.deb && /opt/datadog/createLogPath.sh
- CentOS または Fedora
sudo rpm -Uvh datadog-dotnet-apm<TRACER_VERSION>-1.x86_64.rpm && /opt/datadog/createLogPath.sh
- Alpine などの musl ベースの分布
sudo tar -C /opt/datadog -xzf datadog-dotnet-apm-<TRACER_VERSION>-musl.tar.gz && sh /opt/datadog/createLogPath.sh
- その他の分布
sudo tar -C /opt/datadog -xzf datadog-dotnet-apm-<TRACER_VERSION>.tar.gz && /opt/datadog/createLogPath.sh
Chiseled コンテナ
.NET Tracer を Chiseled または Distroless の Docker イメージ (シェルなし) にインストールするには、次の Dockerfile コマンドを使用します。
ADD
を使用してトレーサー ファイルをコンテナに配置します。COPY --chown=$APP_UID
を使用して、空のフォルダーをソースとしてログ パスを作成します。
Dockerfile の例:
ADD datadog-dotnet-apm-<TRACER_VERSION>.tar.gz /opt/datadog/
COPY --chown=$APP_UID --from=<OTHER_STAGE> /empty/ /var/log/datadog/dotnet/
注: このインストールは、IIS で動作するアプリケーションをインスツルメントするものではありません。IIS で実行されるアプリケーションについては、Windows マシン全体のインストールプロセスに従ってください。
.NET Tracer をアプリケーション単位でインストールするには
Datadog.Trace.Bundle
NuGet パッケージをアプリケーションに追加します。
サービスのトレーサーを有効にする
サービスの .NET Tracer を有効にするには、必要な環境変数を設定し、アプリケーションを再起動します。
環境変数の設定方法の違いについては、プロセス環境変数の構成を参照してください。
.NET Tracer の MSI インストーラーは、必要な環境変数をすべて追加します。構成する必要のある環境変数はありません。
Note: You must set the
.NET CLR version for the application pool to
No Managed Code as recommended by
Microsoft.
IIS でホストされるアプリケーションを自動でインスツルメントするには、管理者として次のコマンドを実行して IIS を完全に停止してから起動します。
net stop /y was
net start w3svc
# Also, start any other services that were stopped when WAS was shut down.
Note: Always use the commands above to completely stop and restart IIS to enable the tracer. Avoid using the IIS Manager GUI application or iisreset.exe
.
IIS にないサービス
自動インスツルメンテーションをアプリケーションにアタッチするために、以下の必要な環境変数を設定します。
CORECLR_ENABLE_PROFILING=1
スタンドアロンアプリケーションや Windows サービスの場合は、手動でアプリケーションを再起動します。
自動インスツルメンテーションをアプリケーションにアタッチするために、以下の必要な環境変数を設定します。
CORECLR_ENABLE_PROFILING=1
CORECLR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
CORECLR_PROFILER_PATH=/opt/datadog/Datadog.Trace.ClrProfiler.Native.so
DD_DOTNET_TRACER_HOME=/opt/datadog
スタンドアロンアプリケーションの場合は、通常通り手動でアプリケーションを再起動します。
ライブデータの表示
サービスの .NET Tracer を有効にした後:
サービスを再起動します。
アプリケーションロードを作成します。
Datadog で APM > APM Traces の順に移動します。
設定
必要に応じて、統合サービスタグ付けの設定など、アプリケーションパフォーマンスのテレメトリーデータを送信するためのトレースライブラリーを構成します。詳しくは、ライブラリの構成を参照してください。
カスタムインスツルメンテーション
カスタムインスツルメンテーションは、自動インスツルメンテーションによって異なり、メソッドによっては追加の手順が含まれます。
注: v3.0.0 以降、カスタム インスツルメンテーションを使用するには自動インスツルメンテーションも併用する必要があります。自動およびカスタム インスツルメンテーションのパッケージ バージョン (例: MSI と NuGet) は同期させ、メジャー バージョンを混在させないようにしてください。
.NET アプリケーションでカスタムインスツルメンテーションを使用するには
- 自動インスツルメンテーションを用いたアプリケーションのインスツルメンテーション。
Datadog.Trace
NuGet パッケージをアプリケーションに追加します。- アプリケーションコードで、
Datadog.Trace.Tracer.Instance
プロパティを介してグローバルトレーサーにアクセスし、新しいスパンを作成します。
注: v3.0.0 以降、カスタム インスツルメンテーションを使用するには自動インスツルメンテーションも併用する必要があります。自動およびカスタム インスツルメンテーションのパッケージ バージョン (例: MSI と NuGet) は同期させ、メジャー バージョンを混在させないようにしてください。
.NET アプリケーションでカスタムインスツルメンテーションを使用するには
- 自動インスツルメンテーションを用いたアプリケーションのインスツルメンテーション。
Datadog.Trace
NuGet パッケージをアプリケーションに追加します。- アプリケーションコードで、
Datadog.Trace.Tracer.Instance
プロパティを介してグローバルトレーサーにアクセスし、新しいスパンを作成します。
.NET アプリケーションでカスタムインスツルメンテーションを使用するには
- アプリケーションコードで、
Datadog.Trace.Tracer.Instance
プロパティを介してグローバルトレーサーにアクセスし、新しいスパンを作成します。
カスタムインスツルメンテーションのスパンやタグの追加について詳しくは、.NET カスタムインスツルメンテーションのドキュメントを参照してください。
プロセス環境変数の構成
サービスに自動インスツルメンテーションをアタッチするには、アプリケーションを起動する前に、必要な環境変数を設定する必要があります。.NET Tracer のインストール方法に応じて設定する環境変数を特定するために、 サービスのトレーサーを有効にするのセクションを参照し、以下の例に従って、インスツルメントされたサービスの環境に基づいて環境変数を正しく設定します。
Windows
注: .NET ランタイムは、これらの環境変数が設定された状態で開始されたあらゆる .NET プロセスに .NET ライブラリをロードしようとします。インスツルメンテーションは、インスツルメントする必要のあるアプリケーションのみに制限する必要があります。これらの環境変数をグローバルに設定しないでください。こうすると、ホスト上のすべての .NET プロセスがインスツルメントされます。
Windows サービス
レジストリエディターで、HKLM\System\CurrentControlSet\Services\<SERVICE NAME>
キーに Environment
複数の文字列値を作成します。
CORECLR_ENABLE_PROFILING=1
Set-ItemProperty HKLM:SYSTEM\CurrentControlSet\Services\<SERVICE NAME> -Name Environment -Value 'CORECLR_ENABLE_PROFILING=1'
IIS
MSI をインストールした後、IIS サイトを自動的にインスツルメンテーションするための追加構成は必要ありません。すべての IIS サイトに継承される追加の環境変数を設定するには、次の手順を実行します。
- Registry Editor を開き、
HKLM\System\CurrentControlSet\Services\WAS
キーにある Environment
という複数文字列の値を探し、1 行に 1 つずつ環境変数を追加します。例えば、ログの挿入とランタイムメトリクスを追加するには、値データに以下の行を追加します。DD_LOGS_INJECTION=true
DD_RUNTIME_METRICS_ENABLED=true
- 以下のコマンドを実行し、IIS を再起動します。
net stop /y was
net start w3svc
# Also, start any other services that were stopped when WAS was shut down.
コンソールアプリケーション
コンソールアプリケーションを自動的にインスツルメントするには、アプリケーションを起動する前に、バッチファイルから環境変数を設定します。
rem 必要な環境変数を設定
SET CORECLR_ENABLE_PROFILING=1
rem (オプション) 追加の Datadog 環境変数を設定。例:
SET DD_LOGS_INJECTION=true
SET DD_RUNTIME_METRICS_ENABLED=true
rem アプリケーションを起動
dotnet.exe example.dll
Linux
Bash スクリプト
アプリケーションを起動する前に、bash ファイルから必要な環境変数を設定するには
# 必要な環境変数を設定
export CORECLR_ENABLE_PROFILING=1
export CORECLR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
export CORECLR_PROFILER_PATH=/opt/datadog/Datadog.Trace.ClrProfiler.Native.so
export DD_DOTNET_TRACER_HOME=/opt/datadog
# (オプション) Datadog の環境変数を追加で設定。例:
export DD_LOGS_INJECTION=true
export DD_RUNTIME_METRICS_ENABLED=true
# アプリケーションを起動
dotnet example.dll
Alpine Linux を使用している場合は、環境変数 CORECLR_PROFILER_PATH
を musl ベースのディストリビューション用のパスに設定してください。例: linux-musl-x64/
Linux Docker コンテナ
Linux Docker コンテナに必要な環境変数を設定するには
# 必要な環境変数を設定
ENV CORECLR_ENABLE_PROFILING=1
ENV CORECLR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
ENV CORECLR_PROFILER_PATH=/opt/datadog/Datadog.Trace.ClrProfiler.Native.so
ENV DD_DOTNET_TRACER_HOME=/opt/datadog
# (オプション) Datadog の環境変数を追加で設定。例:
ENV DD_LOGS_INJECTION=true
ENV DD_RUNTIME_METRICS_ENABLED=true
# アプリケーションを起動
CMD ["dotnet", "example.dll"]
systemctl
(per service)
systemctl
を使用して、サービスとして .NET アプリケーションを実行する場合、特定のサービスに必要な環境変数がロードされるよう追加することができます。
以下を含む、environment.env
というファイルを作成します。
# Set required environment variables
CORECLR_ENABLE_PROFILING=1
CORECLR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
CORECLR_PROFILER_PATH=/opt/datadog/Datadog.Trace.ClrProfiler.Native.so
DD_DOTNET_TRACER_HOME=/opt/datadog
# (Optional) Set additional Datadog environment variables, for example:
DD_LOGS_INJECTION=true
DD_RUNTIME_METRICS_ENABLED=true
サービスのコンフィギュレーションファイルで、サービスブロックの EnvironmentFile
としてこれを参照します。
[Service]
EnvironmentFile=/path/to/environment.env
ExecStart=<command used to start the application>
.NET サービスを再起動して、環境変数の設定を有効にします。
systemctl
(all services)
注: .NET ランタイムは、これらの環境変数が設定された状態で開始されたあらゆる .NET プロセスに .NET ライブラリをロードしようとします。インスツルメンテーションは、インスツルメントする必要のあるアプリケーションのみに制限する必要があります。これらの環境変数をグローバルに設定しないでください。こうすると、ホスト上のすべての .NET プロセスがインスツルメントされます。
systemctl
を使用して .NET アプリケーションをサービスとして実行する場合、systemctl
によって実行されるすべてのサービスに対してロードされる環境変数を設定することもできます。
systemctl set-environment
を実行して、必要な環境変数を設定します。
# Set required environment variables
systemctl set-environment CORECLR_ENABLE_PROFILING=1
systemctl set-environment CORECLR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
systemctl set-environment CORECLR_PROFILER_PATH=/opt/datadog/Datadog.Trace.ClrProfiler.Native.so
systemctl set-environment DD_DOTNET_TRACER_HOME=/opt/datadog
# (Optional) Set additional Datadog environment variables, for example:
systemctl set-environment DD_LOGS_INJECTION=true
systemctl set-environment DD_RUNTIME_METRICS_ENABLED=true
systemctl show-environment
を実行して、環境変数が設定されていることを確認します。
.NET サービスを再起動して、環境変数を有効にします。
関連情報