From 67d0ec93fff4598681f035b21aebf6ad6d92e1d1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 10:41:13 +0100 Subject: [PATCH 01/13] Release 0.5.0-beta.1 --- CHANGELOG.md | 25 ++++++++++--------- OpenTelemetry.DotNet.Auto.psm1 | 4 +-- docs/README.md | 6 ++--- instrument.sh | 4 +-- .../OpenTelemetry.AutoInstrumentation.nuspec | 2 +- otel-dotnet-auto-install.sh | 2 +- ...elemetry.AutoInstrumentation.Loader.csproj | 2 +- .../CMakeLists.txt | 2 +- .../Resource.rc | 4 +-- .../otel_profiler_constants.h | 4 +-- .../version.h | 2 +- .../Constants.cs | 2 +- .../OpenTelemetry.AutoInstrumentation.csproj | 2 +- 13 files changed, 31 insertions(+), 30 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7ef298636e..3020d82ad6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,12 +5,22 @@ All notable changes to this component are documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). This component adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -## [Unreleased](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/compare/v0.4.0-beta.1...HEAD) +## [Unreleased](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/compare/v0.5.0-beta.1...HEAD) + +## [0.5.0-beta.1](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases/tag/v0.5.0-beta.1) + +### Added + +- Add support for .NET 7. +- Add support for `OTEL_DOTNET_AUTO_LOGS_ENABLED`. +- Add error log if bytecode instrumentation type + is missing all instrumentation methods. +- Plugins can overwrite OpenTelemetry .NET SDK exporters' and instrumentations' options. ### Changed -- Replace `OTEL_DOTNET_AUTO_LOAD_TRACER_AT_STARTUP` by `OTEL_DOTNET_AUTO_TRACES_ENABLED` - and `OTEL_DOTNET_AUTO_LOAD_METER_AT_STARTUP` by `OTEL_DOTNET_AUTO_METRICS_ENABLED`. +- Replace `OTEL_DOTNET_AUTO_LOAD_TRACER_AT_STARTUP` with `OTEL_DOTNET_AUTO_TRACES_ENABLED` + and `OTEL_DOTNET_AUTO_LOAD_METER_AT_STARTUP` with `OTEL_DOTNET_AUTO_METRICS_ENABLED`. - Disable OpenTracing by default. OpenTracing can be re-enabled via `OTEL_DOTNET_AUTO_OPENTRACING_ENABLED`. - GraphQL exceptions are recorded as OTel events. @@ -32,15 +42,6 @@ This component adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.h in the PowerShell script module. - `OTEL_DOTNET_AUTO_TRACES_ENABLED` is also respected by bytecode instrumentations -### Added - -- Add support for .NET 7. -- Add support for `OTEL_DOTNET_AUTO_LOGS_ENABLED`. -- Error message on the native log if bytecode instrumentation type is missing all - instrumentation methods [#1499](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/issues/1499). -- Plugins can overwrite OpenTelemetry dotnet SDK instrumentation and exporter options. - See more at [plugins.md](docs/plugins.md). - ## [0.4.0-beta.1](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases/tag/v0.4.0-beta.1) ### Added diff --git a/OpenTelemetry.DotNet.Auto.psm1 b/OpenTelemetry.DotNet.Auto.psm1 index ac95659ac3..1fd5c4b50f 100644 --- a/OpenTelemetry.DotNet.Auto.psm1 +++ b/OpenTelemetry.DotNet.Auto.psm1 @@ -74,7 +74,7 @@ function Get-Environment-Variables-Table([string]$InstallDir, [string]$OTelServi $DOTNET_ADDITIONAL_DEPS = Join-Path $InstallDir "AdditionalDeps" $DOTNET_SHARED_STORE = Join-Path $InstallDir "store" - $DOTNET_STARTUP_HOOKS = Join-Path $InstallDir "netcoreapp3.1/OpenTelemetry.AutoInstrumentation.StartupHook.dll" + $DOTNET_STARTUP_HOOKS = Join-Path $InstallDir "net6.0/OpenTelemetry.AutoInstrumentation.StartupHook.dll" $OTEL_DOTNET_AUTO_HOME = $InstallDir $OTEL_DOTNET_AUTO_INTEGRATIONS_FILE = Join-Path $InstallDir "integrations.json" @@ -197,7 +197,7 @@ function Install-OpenTelemetryCore() { [string]$InstallDir = "" ) - $version = "v0.4.0-beta.1" + $version = "v0.5.0-beta.1" $installDir = Get-CLIInstallDir-From-InstallDir $InstallDir $tempDir = Get-Temp-Directory $dlPath = $null diff --git a/docs/README.md b/docs/README.md index 943d31b833..7a09c8219a 100644 --- a/docs/README.md +++ b/docs/README.md @@ -132,7 +132,7 @@ and instrument your .NET application using the provided Shell scripts. Example usage: ```sh -curl -sSfL https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.4.0-beta.1/otel-dotnet-auto-install.sh -O +curl -sSfL https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.5.0-beta.1/otel-dotnet-auto-install.sh -O sh ./otel-dotnet-auto-install.sh . $HOME/.otel-dotnet-auto/instrument.sh OTEL_SERVICE_NAME=myapp OTEL_RESOURCE_ATTRIBUTES=deployment.environment=staging,service.version=1.0.0 dotnet run @@ -146,7 +146,7 @@ uses environment variables as parameters: | `OTEL_DOTNET_AUTO_HOME` | Location where binaries are to be installed | No | `$HOME/.otel-dotnet-auto` | | `OS_TYPE` | Possible values: `linux-glibc`, `linux-musl`, `macos`, `windows` | No | *Calculated* | | `TMPDIR` | Temporary directory used when downloading the files | No | `$(mktemp -d)` | -| `VERSION` | Version to download | No | `v0.4.0-beta.1` | +| `VERSION` | Version to download | No | `v0.5.0-beta.1` | [instrument.sh](../instrument.sh) script uses environment variables as parameters: @@ -167,7 +167,7 @@ Example usage: ```powershell # Download and import the module -$module_url = "https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.4.0-beta.1/OpenTelemetry.DotNet.Auto.psm1" +$module_url = "https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.5.0-beta.1/OpenTelemetry.DotNet.Auto.psm1" $download_path = Join-Path $env:temp "OpenTelemetry.DotNet.Auto.psm1" Invoke-WebRequest -Uri $module_url -OutFile $download_path Import-Module $download_path diff --git a/instrument.sh b/instrument.sh index d17391aadf..1158c46ec0 100755 --- a/instrument.sh +++ b/instrument.sh @@ -93,9 +93,9 @@ else fi if [ -z "$DOTNET_STARTUP_HOOKS" ]; then - export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/netcoreapp3.1/OpenTelemetry.AutoInstrumentation.StartupHook.dll" + export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/net6.0/OpenTelemetry.AutoInstrumentation.StartupHook.dll" else - export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/netcoreapp3.1/OpenTelemetry.AutoInstrumentation.StartupHook.dll${SEPARATOR}${DOTNET_STARTUP_HOOKS}" + export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/net6.0/OpenTelemetry.AutoInstrumentation.StartupHook.dll${SEPARATOR}${DOTNET_STARTUP_HOOKS}" fi # Configure .NET CLR Profiler diff --git a/nuget/OpenTelemetry.AutoInstrumentation.nuspec b/nuget/OpenTelemetry.AutoInstrumentation.nuspec index 14c4d3a7f9..7e3f82da18 100644 --- a/nuget/OpenTelemetry.AutoInstrumentation.nuspec +++ b/nuget/OpenTelemetry.AutoInstrumentation.nuspec @@ -2,7 +2,7 @@ OpenTelemetry.AutoInstrumentation - 0.4.0-beta.1 + 0.5.0-beta.1 OpenTelemetry Auto-Instrumentation OpenTelemetry Authors OpenTelemetry Authors diff --git a/otel-dotnet-auto-install.sh b/otel-dotnet-auto-install.sh index 52a0193585..41a112f376 100755 --- a/otel-dotnet-auto-install.sh +++ b/otel-dotnet-auto-install.sh @@ -31,7 +31,7 @@ esac test -z "$OTEL_DOTNET_AUTO_HOME" && OTEL_DOTNET_AUTO_HOME="$HOME/.otel-dotnet-auto" test -z "$TMPDIR" && TMPDIR="$(mktemp -d)" -test -z "$VERSION" && VERSION="v0.4.0-beta.1" +test -z "$VERSION" && VERSION="v0.5.0-beta.1" RELEASES_URL="https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases" ARCHIVE="opentelemetry-dotnet-instrumentation-$OS_TYPE.zip" diff --git a/src/OpenTelemetry.AutoInstrumentation.Loader/OpenTelemetry.AutoInstrumentation.Loader.csproj b/src/OpenTelemetry.AutoInstrumentation.Loader/OpenTelemetry.AutoInstrumentation.Loader.csproj index e3acebed42..246b181c35 100644 --- a/src/OpenTelemetry.AutoInstrumentation.Loader/OpenTelemetry.AutoInstrumentation.Loader.csproj +++ b/src/OpenTelemetry.AutoInstrumentation.Loader/OpenTelemetry.AutoInstrumentation.Loader.csproj @@ -6,7 +6,7 @@ ..\bin\ProfilerResources\ - 0.4.0 + 0.5.0 false diff --git a/src/OpenTelemetry.AutoInstrumentation.Native/CMakeLists.txt b/src/OpenTelemetry.AutoInstrumentation.Native/CMakeLists.txt index 2d556e3bf0..00e653e16f 100644 --- a/src/OpenTelemetry.AutoInstrumentation.Native/CMakeLists.txt +++ b/src/OpenTelemetry.AutoInstrumentation.Native/CMakeLists.txt @@ -5,7 +5,7 @@ cmake_policy(SET CMP0015 NEW) # Project definition # ****************************************************** -project("OpenTelemetry.AutoInstrumentation.Native" VERSION 0.4.0) +project("OpenTelemetry.AutoInstrumentation.Native" VERSION 0.5.0) # ****************************************************** # Environment detection diff --git a/src/OpenTelemetry.AutoInstrumentation.Native/Resource.rc b/src/OpenTelemetry.AutoInstrumentation.Native/Resource.rc index 62a712b4e6..17a3c5f1bc 100644 --- a/src/OpenTelemetry.AutoInstrumentation.Native/Resource.rc +++ b/src/OpenTelemetry.AutoInstrumentation.Native/Resource.rc @@ -67,12 +67,12 @@ BEGIN BEGIN VALUE "CompanyName", "The OpenTelemetry Authors" VALUE "FileDescription", "OpenTelemetry CLR Profiler" - VALUE "FileVersion", "0.4.0.0" + VALUE "FileVersion", "0.5.0.0" VALUE "InternalName", "OpenTelemetry.AutoInstrumentation.Native.DLL" VALUE "LegalCopyright", "Copyright 2021 The OpenTelemetry Authors" VALUE "OriginalFilename", "OpenTelemetry.AutoInstrumentation.Native.DLL" VALUE "ProductName", "OpenTelemetry .NET AutoInstrumentation" - VALUE "ProductVersion", "0.4.0" + VALUE "ProductVersion", "0.5.0" END END BLOCK "VarFileInfo" diff --git a/src/OpenTelemetry.AutoInstrumentation.Native/otel_profiler_constants.h b/src/OpenTelemetry.AutoInstrumentation.Native/otel_profiler_constants.h index d46554d859..8231c19571 100644 --- a/src/OpenTelemetry.AutoInstrumentation.Native/otel_profiler_constants.h +++ b/src/OpenTelemetry.AutoInstrumentation.Native/otel_profiler_constants.h @@ -64,10 +64,10 @@ const WSTRING opentelemetry_autoinstrumentation_loader_assemblyName = WStr("Open const WSTRING managed_profiler_name = WStr("OpenTelemetry.AutoInstrumentation"); const WSTRING managed_profiler_full_assembly_version = - WStr("OpenTelemetry.AutoInstrumentation, Version=0.4.0.0, Culture=neutral, PublicKeyToken=null"); + WStr("OpenTelemetry.AutoInstrumentation, Version=0.5.0.0, Culture=neutral, PublicKeyToken=null"); const WSTRING managed_profiler_full_assembly_version_strong_name = - WStr("OpenTelemetry.AutoInstrumentation, Version=0.4.0.0, Culture=neutral, PublicKeyToken=c0db600a13f60b51"); + WStr("OpenTelemetry.AutoInstrumentation, Version=0.5.0.0, Culture=neutral, PublicKeyToken=c0db600a13f60b51"); const WSTRING nonwindows_nativemethods_type = WStr("OpenTelemetry.AutoInstrumentation.NativeMethods+NonWindows"); diff --git a/src/OpenTelemetry.AutoInstrumentation.Native/version.h b/src/OpenTelemetry.AutoInstrumentation.Native/version.h index b6a501e63c..cd937572eb 100644 --- a/src/OpenTelemetry.AutoInstrumentation.Native/version.h +++ b/src/OpenTelemetry.AutoInstrumentation.Native/version.h @@ -1,3 +1,3 @@ #pragma once -constexpr auto PROFILER_VERSION = "0.4.0"; +constexpr auto PROFILER_VERSION = "0.5.0"; diff --git a/src/OpenTelemetry.AutoInstrumentation/Constants.cs b/src/OpenTelemetry.AutoInstrumentation/Constants.cs index dc9b38a77b..d82246dc83 100644 --- a/src/OpenTelemetry.AutoInstrumentation/Constants.cs +++ b/src/OpenTelemetry.AutoInstrumentation/Constants.cs @@ -20,7 +20,7 @@ internal static class Constants { public static class Tracer { - public const string Version = "0.4.0"; + public const string Version = "0.5.0"; public const string AutoInstrumentationVersionName = "telemetry.auto.version"; } diff --git a/src/OpenTelemetry.AutoInstrumentation/OpenTelemetry.AutoInstrumentation.csproj b/src/OpenTelemetry.AutoInstrumentation/OpenTelemetry.AutoInstrumentation.csproj index d05789bee1..dc0e1cb63b 100644 --- a/src/OpenTelemetry.AutoInstrumentation/OpenTelemetry.AutoInstrumentation.csproj +++ b/src/OpenTelemetry.AutoInstrumentation/OpenTelemetry.AutoInstrumentation.csproj @@ -3,7 +3,7 @@ - 0.4.0 + 0.5.0 From 36ecc878b2bb77a0f005b0fd737eb5ba575c5dd1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 10:42:44 +0100 Subject: [PATCH 02/13] Add missing dot --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 3020d82ad6..c19ad4f479 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -40,7 +40,7 @@ This component adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.h - Fix the IIS unregistration in the PowerShell script module. - Get rid of unnecessary service restarts during the IIS unregistration, in the PowerShell script module. -- `OTEL_DOTNET_AUTO_TRACES_ENABLED` is also respected by bytecode instrumentations +- `OTEL_DOTNET_AUTO_TRACES_ENABLED` is also respected by bytecode instrumentations. ## [0.4.0-beta.1](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases/tag/v0.4.0-beta.1) From b507e85025785d192861ad67d998e45690a343c0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 11:36:01 +0100 Subject: [PATCH 03/13] Update validate-documentation.yml --- .github/workflows/validate-documentation.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/validate-documentation.yml b/.github/workflows/validate-documentation.yml index 80952902f1..f750150cb0 100644 --- a/.github/workflows/validate-documentation.yml +++ b/.github/workflows/validate-documentation.yml @@ -30,6 +30,7 @@ jobs: fail: true env: GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} + if: ${{ !contains(github.event.pull_request.labels.*.name, 'release PR') }} - run: npm install From db0f9a2e2890f13ae34a38166f0a938e12c14682 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 11:36:46 +0100 Subject: [PATCH 04/13] Update ci.yml --- .github/workflows/ci.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 3de0d141cb..3cb9edc6bf 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -64,6 +64,7 @@ jobs: continue-on-error: true powershell-script: + if: ${{ !contains(github.event.pull_request.labels.*.name, 'release PR') }} runs-on: windows-2022 steps: - uses: actions/setup-dotnet@v3.0.3 @@ -92,6 +93,7 @@ jobs: if (Test-Path $install_dir) { throw "Core files exist. Core uninstall failed." } shell-scripts: + if: ${{ !contains(github.event.pull_request.labels.*.name, 'release PR') }} strategy: fail-fast: false matrix: From c692959acf4855002e1b9725cd52118d92e87008 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 11:38:03 +0100 Subject: [PATCH 05/13] Update ci.yml --- .github/workflows/ci.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 3cb9edc6bf..c8681384e7 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -127,6 +127,7 @@ jobs: test "$(ls -A '${{ matrix.log-dir }}' )" shell-scripts-container: + if: ${{ !contains(github.event.pull_request.labels.*.name, 'release PR') }} strategy: fail-fast: false matrix: From a50e04ce24ecef5555e5e510ec2f00b7c26717a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 11:39:33 +0100 Subject: [PATCH 06/13] Update releasing.md --- docs/releasing.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/docs/releasing.md b/docs/releasing.md index 5999a81c11..b979279ee9 100644 --- a/docs/releasing.md +++ b/docs/releasing.md @@ -18,9 +18,8 @@ 1. Stable release only! Update `PublicAPI.Shipped.txt` based on corresponding `PublicAPI.Unshipped.txt`. -1. Create a pull request on GitHub with the changes described in the changelog. - - `*scripts*` and `validate-documentation` jobs will fail - because the release is not published yet. +1. Create a pull request with `release PR` label on GitHub + with the changes described in the changelog. 1. Run the integration tests with Linux containers on Windows and macOS (not covered by CI): From 89a6c9059aa77ac3c5c0ec0e0e11b95e6d805c6b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 17:45:16 +0100 Subject: [PATCH 07/13] Update CHANGELOG.md --- CHANGELOG.md | 2 -- 1 file changed, 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c19ad4f479..7bcb837921 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -31,8 +31,6 @@ This component adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.h - Remove support for `OTEL_DOTNET_AUTO_ENABLED`. Use `CORECLR_ENABLE_PROFILING` or `COR_ENABLE_PROFILING` instead. - Remove support for `OTEL_DOTNET_AUTO_INCLUDE_PROCESSES`. -- Remove traces instrumentation for [System.Data.SqlClient](https://www.nuget.org/packages/System.Data.SqlClient) - as it is not working. ### Fixed From 32d6feaeaf2aedf4f3b9fc973ffa90103094e728 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 17:47:10 +0100 Subject: [PATCH 08/13] Update config.md --- docs/config.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/config.md b/docs/config.md index 512389c5d0..3b25a0465b 100644 --- a/docs/config.md +++ b/docs/config.md @@ -43,7 +43,7 @@ for more details. | `MongoDB` | [MongoDB.Driver.Core](https://www.nuget.org/packages/MongoDB.Driver.Core) **Not supported on .NET Framework** | ≥2.13.3 & < 3.0.0 | source & bytecode | | `MySqlData` | [MySql.Data](https://www.nuget.org/packages/MySql.Data) **Not supported on .NET Framework** | ≥6.10.7 | source & bytecode \[1\] | | `Npgsql` | [Npgsql](https://www.nuget.org/packages/Npgsql) | ≥6.0.0 | source | -| `SqlClient` | [Microsoft.Data.SqlClient](https://www.nuget.org/packages/Microsoft.Data.SqlClient) | * | source | +| `SqlClient` | [Microsoft.Data.SqlClient](https://www.nuget.org/packages/Microsoft.Data.SqlClient) and [System.Data.SqlClient](https://www.nuget.org/packages/System.Data.SqlClient) | * | source | | `StackExchangeRedis` | [StackExchange.Redis](https://www.nuget.org/packages/StackExchange.Redis) **Not supported on .NET Framework** | ≥2.0.405 < 3.0.0 | source & bytecode | | `Wcf` | [System.ServiceModel](https://www.nuget.org/packages/System.ServiceModel) **No support for server side on .NET**. For configuration see [WCF Instrumentation Configuration](wcf-config.md) | * \[2\] | source | From 0c306c7784669070898c32cdd6cc77f9abf6123a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 17:47:45 +0100 Subject: [PATCH 09/13] Update instrumentation-libraries.md --- docs/internal/instrumentation-libraries.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/internal/instrumentation-libraries.md b/docs/internal/instrumentation-libraries.md index 688bea55a0..5bc1daaf99 100644 --- a/docs/internal/instrumentation-libraries.md +++ b/docs/internal/instrumentation-libraries.md @@ -36,7 +36,7 @@ submit an issue to request its inclusion. | [Entity Framework Core](https://docs.microsoft.com/ef/core/) | | | | Needs investigation. It might be implicitly supported based on the configured [database provider](https://docs.microsoft.com/ef/core/providers/). | | [Dapper](https://github.com/DapperLib/Dapper) | | | | Needs investigation. It might be implicitly supported based on the configured [database provider](https://github.com/DapperLib/Dapper#will-dapper-work-with-my-db-provider). | | [Microsoft.Data.SqlClient](https://www.nuget.org/packages/Microsoft.Data.SqlClient) | Yes | | [MS SQL Server](https://www.microsoft.com/sql-server/sql-server-2019) | | -| [System.Data.SqlClient](https://www.nuget.org/packages/System.Data.SqlClient) | | | | | +| [System.Data.SqlClient](https://www.nuget.org/packages/System.Data.SqlClient) | Yes | | | | | [MySql.Data](https://dev.mysql.com/doc/connector-net/en/connector-net-introduction.html) | Partial[^not_on_framework] | | | This is the official [MySQL](https://dev.mysql.com/) library. | | [MySqlConnector](https://mysqlconnector.net/) | | | | Seems to be the [recommended library for MariaDB](https://mariadb.com/kb/en/mysqlconnector-for-adonet/). | | [Npgsql](https://www.npgsql.org/) | Yes | | [PostgreSQL](https://www.postgresql.org/) | | From 287bd7a21b44d27a170e7d7c8e12916db376ac23 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Wed, 23 Nov 2022 19:15:47 +0100 Subject: [PATCH 10/13] Change 0.5.0-beta.1 to 0.5.0 --- CHANGELOG.md | 4 ++-- OpenTelemetry.DotNet.Auto.psm1 | 2 +- docs/README.md | 6 +++--- nuget/OpenTelemetry.AutoInstrumentation.nuspec | 2 +- otel-dotnet-auto-install.sh | 2 +- 5 files changed, 8 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7bcb837921..45fc552a56 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,9 +5,9 @@ All notable changes to this component are documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). This component adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -## [Unreleased](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/compare/v0.5.0-beta.1...HEAD) +## [Unreleased](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/compare/v0.5.0...HEAD) -## [0.5.0-beta.1](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases/tag/v0.5.0-beta.1) +## [0.5.0](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases/tag/v0.5.0) ### Added diff --git a/OpenTelemetry.DotNet.Auto.psm1 b/OpenTelemetry.DotNet.Auto.psm1 index 1fd5c4b50f..2bf2d2c242 100644 --- a/OpenTelemetry.DotNet.Auto.psm1 +++ b/OpenTelemetry.DotNet.Auto.psm1 @@ -197,7 +197,7 @@ function Install-OpenTelemetryCore() { [string]$InstallDir = "" ) - $version = "v0.5.0-beta.1" + $version = "v0.5.0" $installDir = Get-CLIInstallDir-From-InstallDir $InstallDir $tempDir = Get-Temp-Directory $dlPath = $null diff --git a/docs/README.md b/docs/README.md index 7a09c8219a..8043b18825 100644 --- a/docs/README.md +++ b/docs/README.md @@ -132,7 +132,7 @@ and instrument your .NET application using the provided Shell scripts. Example usage: ```sh -curl -sSfL https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.5.0-beta.1/otel-dotnet-auto-install.sh -O +curl -sSfL https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.5.0/otel-dotnet-auto-install.sh -O sh ./otel-dotnet-auto-install.sh . $HOME/.otel-dotnet-auto/instrument.sh OTEL_SERVICE_NAME=myapp OTEL_RESOURCE_ATTRIBUTES=deployment.environment=staging,service.version=1.0.0 dotnet run @@ -146,7 +146,7 @@ uses environment variables as parameters: | `OTEL_DOTNET_AUTO_HOME` | Location where binaries are to be installed | No | `$HOME/.otel-dotnet-auto` | | `OS_TYPE` | Possible values: `linux-glibc`, `linux-musl`, `macos`, `windows` | No | *Calculated* | | `TMPDIR` | Temporary directory used when downloading the files | No | `$(mktemp -d)` | -| `VERSION` | Version to download | No | `v0.5.0-beta.1` | +| `VERSION` | Version to download | No | `v0.5.0` | [instrument.sh](../instrument.sh) script uses environment variables as parameters: @@ -167,7 +167,7 @@ Example usage: ```powershell # Download and import the module -$module_url = "https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.5.0-beta.1/OpenTelemetry.DotNet.Auto.psm1" +$module_url = "https://raw.githubusercontent.com/open-telemetry/opentelemetry-dotnet-instrumentation/v0.5.0/OpenTelemetry.DotNet.Auto.psm1" $download_path = Join-Path $env:temp "OpenTelemetry.DotNet.Auto.psm1" Invoke-WebRequest -Uri $module_url -OutFile $download_path Import-Module $download_path diff --git a/nuget/OpenTelemetry.AutoInstrumentation.nuspec b/nuget/OpenTelemetry.AutoInstrumentation.nuspec index 7e3f82da18..069b2f8ef7 100644 --- a/nuget/OpenTelemetry.AutoInstrumentation.nuspec +++ b/nuget/OpenTelemetry.AutoInstrumentation.nuspec @@ -2,7 +2,7 @@ OpenTelemetry.AutoInstrumentation - 0.5.0-beta.1 + 0.5.0 OpenTelemetry Auto-Instrumentation OpenTelemetry Authors OpenTelemetry Authors diff --git a/otel-dotnet-auto-install.sh b/otel-dotnet-auto-install.sh index 41a112f376..a6115c3b27 100755 --- a/otel-dotnet-auto-install.sh +++ b/otel-dotnet-auto-install.sh @@ -31,7 +31,7 @@ esac test -z "$OTEL_DOTNET_AUTO_HOME" && OTEL_DOTNET_AUTO_HOME="$HOME/.otel-dotnet-auto" test -z "$TMPDIR" && TMPDIR="$(mktemp -d)" -test -z "$VERSION" && VERSION="v0.5.0-beta.1" +test -z "$VERSION" && VERSION="v0.5.0" RELEASES_URL="https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation/releases" ARCHIVE="opentelemetry-dotnet-instrumentation-$OS_TYPE.zip" From b929793d370bbfdd03647dc4c0de680ff53c6664 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 24 Nov 2022 12:44:02 +0100 Subject: [PATCH 11/13] Update DOTNET_STARTUP_HOOKS value --- CHANGELOG.md | 1 + OpenTelemetry.DotNet.Auto.psm1 | 2 +- instrument.sh | 4 ++-- 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 45fc552a56..7914128e17 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -23,6 +23,7 @@ This component adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.h and `OTEL_DOTNET_AUTO_LOAD_METER_AT_STARTUP` with `OTEL_DOTNET_AUTO_METRICS_ENABLED`. - Disable OpenTracing by default. OpenTracing can be re-enabled via `OTEL_DOTNET_AUTO_OPENTRACING_ENABLED`. - GraphQL exceptions are recorded as OTel events. +- `DOTNET_STARTUP_HOOKS` required value changed to `$INSTALL_DIR/net/OpenTelemetry.AutoInstrumentation.StartupHook.dll`. ### Removed diff --git a/OpenTelemetry.DotNet.Auto.psm1 b/OpenTelemetry.DotNet.Auto.psm1 index 2bf2d2c242..efafb4267c 100644 --- a/OpenTelemetry.DotNet.Auto.psm1 +++ b/OpenTelemetry.DotNet.Auto.psm1 @@ -74,7 +74,7 @@ function Get-Environment-Variables-Table([string]$InstallDir, [string]$OTelServi $DOTNET_ADDITIONAL_DEPS = Join-Path $InstallDir "AdditionalDeps" $DOTNET_SHARED_STORE = Join-Path $InstallDir "store" - $DOTNET_STARTUP_HOOKS = Join-Path $InstallDir "net6.0/OpenTelemetry.AutoInstrumentation.StartupHook.dll" + $DOTNET_STARTUP_HOOKS = Join-Path $InstallDir "net/OpenTelemetry.AutoInstrumentation.StartupHook.dll" $OTEL_DOTNET_AUTO_HOME = $InstallDir $OTEL_DOTNET_AUTO_INTEGRATIONS_FILE = Join-Path $InstallDir "integrations.json" diff --git a/instrument.sh b/instrument.sh index 1158c46ec0..1fe8b040ca 100755 --- a/instrument.sh +++ b/instrument.sh @@ -93,9 +93,9 @@ else fi if [ -z "$DOTNET_STARTUP_HOOKS" ]; then - export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/net6.0/OpenTelemetry.AutoInstrumentation.StartupHook.dll" + export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/net/OpenTelemetry.AutoInstrumentation.StartupHook.dll" else - export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/net6.0/OpenTelemetry.AutoInstrumentation.StartupHook.dll${SEPARATOR}${DOTNET_STARTUP_HOOKS}" + export DOTNET_STARTUP_HOOKS="${OTEL_DOTNET_AUTO_HOME}/net/OpenTelemetry.AutoInstrumentation.StartupHook.dll${SEPARATOR}${DOTNET_STARTUP_HOOKS}" fi # Configure .NET CLR Profiler From 925dc8a3ca800ddd2fe0b3ab771589343228bc30 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 24 Nov 2022 12:54:02 +0100 Subject: [PATCH 12/13] Add ASPNETCORE_HOSTINGSTARTUPASSEMBLIES to envvars.sh --- dev/envvars.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/dev/envvars.sh b/dev/envvars.sh index fe64b31ab7..5f0f473ed3 100644 --- a/dev/envvars.sh +++ b/dev/envvars.sh @@ -60,6 +60,9 @@ export DOTNET_ADDITIONAL_DEPS="${CURDIR}/bin/tracer-home/AdditionalDeps" export DOTNET_SHARED_STORE="${CURDIR}/bin/tracer-home/store" export DOTNET_STARTUP_HOOKS="${CURDIR}/bin/tracer-home/net/OpenTelemetry.AutoInstrumentation.StartupHook.dll" +# Configure ASP.NET Core startup +export ASPNETCORE_HOSTINGSTARTUPASSEMBLIES="OpenTelemetry.AutoInstrumentation.AspNetCoreBootstrapper" + # Configure OpenTelemetry .NET Auto-Instrumentation export OTEL_DOTNET_AUTO_HOME="${CURDIR}/bin/tracer-home" export OTEL_DOTNET_AUTO_INTEGRATIONS_FILE="${CURDIR}/bin/tracer-home/integrations.json" From 8c2dd09990d1afd7092e60d3c0b0fd7de5311522 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Paj=C4=85k?= Date: Thu, 24 Nov 2022 13:45:18 +0100 Subject: [PATCH 13/13] Fix plugin publish in examples --- run-example.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/run-example.sh b/run-example.sh index ebb4af2f70..120f2d5dd1 100644 --- a/run-example.sh +++ b/run-example.sh @@ -36,7 +36,7 @@ if [[ $skipAppBuild != "true" && $skipAppBuild != "1" ]]; then dotnet publish -f $aspNetAppTargetFramework -c $configuration ./examples/AspNetCoreMvc/Examples.AspNetCoreMvc.csproj # build plugin for HTTP server app - dotnet publish -f $vendorPluginTargetFramework -c $configuration ./examples/Vendor.Distro/Examples.Vendor.Distro.csproj -o bin/tracer-home/$vendorPluginTargetFramework + dotnet publish -f $vendorPluginTargetFramework -c $configuration ./examples/Vendor.Distro/Examples.Vendor.Distro.csproj -o bin/tracer-home/net # build the client app dotnet publish -f $exampleAppTargetFramework -c $configuration ./examples/${exampleApp}/Examples.${exampleApp}.csproj