opentelemetry-java-instrume.../examples/extension
dependabot[bot] b94688e308
Bump testcontainers from 1.17.5 to 1.17.6 in /examples/extension (#7205)
Bumps
[testcontainers](https://github.com/testcontainers/testcontainers-java)
from 1.17.5 to 1.17.6.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/testcontainers/testcontainers-java/releases">testcontainers's
releases</a>.</em></p>
<blockquote>
<h2>1.17.6</h2>
<h1>What's Changed</h1>
<h2>Highlights</h2>
<p>This release has been made possible through the efforts of 20
contributors. The Testcontainers does not cease to amaze us, thanks to
everyone of you and thanks for the ongoing support and collaboration
🥰.</p>
<p>This release brings a lot of database love with 2 new modules, and as
always a couple of bug fixes and improvements</p>
<h3>New Module: QuestDB (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/5995">#5995</a>)
<a href="https://github.com/Vangreen"><code>@​Vangreen</code></a></h3>
<p><a href="https://questdb.io/">QuestDB</a>, is a high-performance,
open-source SQL database for applications in financial services, IoT,
machine learning, DevOps and observability.</p>
<pre lang="java"><code>var container = new
QuestDBContainer(&quot;questdb/questdb:6.5.3&quot;)
container.start()
var connectionUrl = container.getHttpUrl()
// use the connectionUrl and start testing!
</code></pre>
<h3>New Module: YugabyteDB (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/4372">#4372</a>)
<a
href="https://github.com/srinivasa-vasu"><code>@​srinivasa-vasu</code></a></h3>
<p><a href="https://www.yugabyte.com/">YugabyteDB</a>, is a modern
distributed SQL database for transactional cloud native applications.
PostgreSQL compatible. It offers two APIs, SQL and CQL.</p>
<pre lang="java"><code>var container = new
YugabyteDBYSQLContainer(&quot;yugabytedb/yugabyte:2.14.4.0-b26&quot;);
container.start()
var jdbcUrl = container.getJdbcUrl();
// use the jdbcUrl and start testing!
</code></pre>
<pre lang="java"><code>var container = new
YugabyteDBYCQLContainer(&quot;yugabytedb/yugabyte:2.14.4.0-b26&quot;);
container.start()
var contactPoint = container.getContactPoint();
// use the contactPoint and start testing!
</code></pre>
<h2>🚀 Features &amp; Enhancements</h2>
<ul>
<li>InfluxDB v2 support (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/3669">#3669</a>)
<a href="https://github.com/raminqaf"><code>@​raminqaf</code></a></li>
<li>Add support for flags in DatastoreEmulatorContainer (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/5993">#5993</a>)
<a
href="https://github.com/eddumelendez"><code>@​eddumelendez</code></a></li>
<li>Expose Redpanda schema registry (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/5994">#5994</a>)
<a
href="https://github.com/gustavomonarin"><code>@​gustavomonarin</code></a></li>
<li>Adds the ability to set a target build stage to a Dockerfile (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/4810">#4810</a>)
<a
href="https://github.com/GenghisChen"><code>@​GenghisChen</code></a></li>
</ul>
<h2>🐛 Bug Fixes</h2>
<ul>
<li>Fixes wrong timestamp calculation (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/5988">#5988</a>)
<a href="https://github.com/leblonk"><code>@​leblonk</code></a></li>
<li>Catch and ignore more errors when reflecting into container subclass
(<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/5990">#5990</a>)
<a href="https://github.com/akhaku"><code>@​akhaku</code></a></li>
<li>Return default for empty environment variable (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/5983">#5983</a>)
<a href="https://github.com/roulpriya"><code>@​roulpriya</code></a></li>
</ul>
<h2>📖 Documentation</h2>
<ul>
<li>Add Spotify in Donors section (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/6083">#6083</a>)
<a
href="https://github.com/eddumelendez"><code>@​eddumelendez</code></a></li>
</ul>
<!-- raw HTML omitted -->
</blockquote>
<p>... (truncated)</p>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="4a2ca136cf"><code>4a2ca13</code></a>
Merge pull request <a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/6212">#6212</a>
from testcontainers/combined-pr-branch</li>
<li><a
href="388af569e9"><code>388af56</code></a>
Merge remote-tracking branch
'origin/dependabot/gradle/modules/localstack/com...</li>
<li><a
href="2748cf8f33"><code>2748cf8</code></a>
Merge remote-tracking branch
'origin/dependabot/gradle/modules/localstack/com...</li>
<li><a
href="889ea6b3f5"><code>889ea6b</code></a>
Add yugabytedb to mkdocs.yml (<a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/6211">#6211</a>)</li>
<li><a
href="c17467606c"><code>c174676</code></a>
Bump aws-java-sdk-logs from 1.12.337 to 1.12.343 in
/modules/localstack</li>
<li><a
href="c2abe0d245"><code>c2abe0d</code></a>
Bump aws-java-sdk-s3 from 1.12.337 to 1.12.343 in
/modules/localstack</li>
<li><a
href="11c3079ba5"><code>11c3079</code></a>
Merge pull request <a
href="https://github-redirect.dependabot.com/testcontainers/testcontainers-java/issues/6210">#6210</a>
from testcontainers/combined-pr-branch</li>
<li><a
href="aed19b8c3a"><code>aed19b8</code></a>
Merge remote-tracking branch
'origin/dependabot/gradle/modules/dynalite/com.a...</li>
<li><a
href="6633109869"><code>6633109</code></a>
Merge remote-tracking branch
'origin/dependabot/gradle/modules/gcloud/com.goo...</li>
<li><a
href="fa867b0d57"><code>fa867b0</code></a>
Merge remote-tracking branch
'origin/dependabot/gradle/examples/org.jetbrains...</li>
<li>Additional commits viewable in <a
href="https://github.com/testcontainers/testcontainers-java/compare/1.17.5...1.17.6">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=org.testcontainers:testcontainers&package-manager=gradle&previous-version=1.17.5&new-version=1.17.6)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

You can trigger a rebase of this PR by commenting `@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2022-11-17 09:51:15 +01:00
..
gradle/wrapper Update gradle to 7.5.1 (#6359) 2022-08-12 12:03:43 +02:00
src Remove deprecated code (#6501) 2022-08-24 14:36:57 -07:00
README.md Introduce markdown lint check (#7175) 2022-11-16 20:48:42 -08:00
build.gradle Bump testcontainers from 1.17.5 to 1.17.6 in /examples/extension (#7205) 2022-11-17 09:51:15 +01:00
gradle.properties Run Gradle and compile code with Java 17 (#5623) 2022-03-18 15:38:51 -07:00
gradlew Update gradle to 7.5.1 (#6359) 2022-08-12 12:03:43 +02:00
gradlew.bat Update gradle to 7.5.1 (#6359) 2022-08-12 12:03:43 +02:00
settings.gradle Sync gradle-plugins version with main project (#4248) 2021-10-29 10:34:49 -07:00

README.md

Extensions

Introduction

Extensions add new features and capabilities to the agent without having to create a separate distribution (for examples and ideas, see Use cases for extensions).

The contents in this folder demonstrate how to create an extension for the OpenTelemetry Java instrumentation agent, with examples for every extension point.

Read both the source code and the Gradle build script, as they contain documentation that explains the purpose of all the major components.

Build and add extensions

To build this extension project, run ./gradlew build. You can find the resulting jar file in build/libs/.

To add the extension to the instrumentation agent:

  1. Copy the jar file to a host that is running an application to which you've attached the OpenTelemetry Java instrumentation.

  2. Modify the startup command to add the full path to the extension file. For example:

    java -javaagent:path/to/opentelemetry-javaagent.jar \
         -Dotel.javaagent.extensions=build/libs/opentelemetry-java-instrumentation-extension-demo-1.0-all.jar
         -jar myapp.jar
    

Note: to load multiple extensions, you can specify a comma-separated list of extension jars or directories (that contain extension jars) for the otel.javaagent.extensions value.

Embed extensions in the OpenTelemetry Agent

To simplify deployment, you can embed extensions into the OpenTelemetry Java Agent to produce a single jar file. With an integrated extension, you no longer need the -Dotel.javaagent.extensions command line option.

For more information, see the extendedAgent task in build.gradle.

Extensions examples

Sample use cases

Extensions are designed to override or customize the instrumentation provided by the upstream agent without having to create a new OpenTelemetry distribution or alter the agent code in any way.

Consider an instrumented database client that creates a span per database call and extracts data from the database connection to provide span attributes. The following are sample use cases for that scenario that can be solved by using extensions.

"I don't want this span at all"

Create an extension to disable selected instrumentation by providing new default settings.

"I want to edit some attributes that don't depend on any db connection instance"

Create an extension that provide a custom SpanProcessor.

"I want to edit some attributes and their values depend on a specific db connection instance"

Create an extension with new instrumentation which injects its own advice into the same method as the original one. You can use the order method to ensure it runs after the original instrumentation and augment the current span with new information.

For example, see DemoServlet3InstrumentationModule.

"I want to remove some attributes"

Create an extension with a custom exporter or use the attribute filtering functionality in the OpenTelemetry Collector.

"I don't like the OTel spans. I want to modify them and their lifecycle"

Create an extension that disables existing instrumentation and replace it with new one that injects Advice into the same (or a better) method as the original instrumentation. You can write your Advice for this and use the existing Tracer directly or extend it. As you have your own Advice, you can control which Tracer you use.