Skip to content

Commit

Permalink
Add Go Auto-Instrumentation Beta Announcement Blog Post (#6079)
Browse files Browse the repository at this point in the history
Co-authored-by: Severin Neumann <[email protected]>
Co-authored-by: Tiffany Hrabusa <[email protected]>
Co-authored-by: opentelemetrybot <[email protected]>
  • Loading branch information
4 people authored Jan 30, 2025
1 parent 8b577fa commit 140ad81
Show file tree
Hide file tree
Showing 2 changed files with 164 additions and 0 deletions.
124 changes: 124 additions & 0 deletions content/en/blog/2025/go-auto-instrumentation-beta.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
---
# prettier-ignore
title: Announcing the Beta Release of OpenTelemetry Go Auto-Instrumentation using eBPF
linkTitle: Go Auto-Instrumentation Beta
date: 2025-01-30
# prettier-ignore
author: >-
[Tyler Yahn](https://github.com/MrAlias) (Splunk)
[Mike Dame](https://github.com/damemi) (Odigos)
sig: SIG Go Auto-Instrumentation
# prettier-ignore
cSpell:ignore: Yahn Odigos rolldice Beyla's Beyla
---

The OpenTelemetry community is excited to announce the beta release of the
[OpenTelemetry Go Auto-Instrumentation project](https://github.com/open-telemetry/opentelemetry-go-instrumentation)!
This milestone brings us closer to our mission of making observability simple,
accessible, and effective for Go applications.

## What is Go Auto-Instrumentation?

OpenTelemetry Go Auto-Instrumentation allows developers to collect traces from
their Go applications without requiring manual code modifications or rebuilding
binaries. By dynamically instrumenting applications at runtime using
[eBPF](https://ebpf.io/), this project lowers the barrier to adopting
observability best practices and provides deep insights into your application's
behavior.

## Key features of the beta release

The beta release offers foundational support for automatic instrumentation with
these key features:

- **HTTP server instrumentation**: Automatically trace incoming and outgoing
HTTP requests with trace context propagation when using the
[`net/http` package](https://pkg.go.dev/net/http).
- **Database instrumentation**: Instrument database queries and connections that
use the [`database/sql` package](https://pkg.go.dev/database/sql).
- **gRPC instrumentation**: Easily collect telemetry data from
[gRPC clients and servers](https://pkg.go.dev/google.golang.org/grpc).
- **Kafka-go instrumentation**: Monitor and trace Kafka messaging using the
[`kafka-go` package](https://pkg.go.dev/github.com/segmentio/kafka-go).
- **Extensible with OpenTelemetry’s Trace API**: Seamlessly extend
auto-instrumentation with custom spans using the
[OpenTelemetry Go Trace API](https://pkg.go.dev/go.opentelemetry.io/otel).
- **Configuration using environment variables**: Simplify configuration with
environment-based settings, reducing the need for code changes.
- **Semantic convention compliance**: Produced telemetry complies with the
latest OpenTelemetry semantic conventions ensuring compatibility with the OTel
ecosystem.

## Getting started

Getting started with OpenTelemetry Go Auto-Instrumentation is straightforward!
For detailed instructions on installation, configuration, and running your
application with auto-instrumentation, check out the
[Getting Started guide](https://github.com/open-telemetry/opentelemetry-go-instrumentation/blob/main/docs/getting-started.md).

To see a complete example, check out the
[`rolldice` application](https://github.com/open-telemetry/opentelemetry-go-instrumentation/tree/0ebb7f21116bfdd8e29c315efdbf359cd74bddac/examples/rolldice).

## The road to stabilization

With the beta release now available, the project team is focused on preparing
for a stable release. Over the coming year, we’ll concentrate on achieving the
following goals:

1. **Optimize runtime instrumentation with eBPF**

We will continue to leverage and improve eBPF for dynamic runtime
instrumentation, ensuring that Go applications have reliable, low-overhead
observability. This includes staying up to date with the latest developments
in both the Go and eBPF ecosystems.

2. **Expand ecosystem support**

While the beta release supports a limited number of Go packages and only a
single telemetry processing pipeline, we plan to broaden this support. We’ll
introduce instrumentation for additional Go packages and allow users to
create custom telemetry processing pipelines. This expansion will make it
easier to integrate with popular Go packages and provide flexibility for
custom instrumentation.

3. **Integrate with Beyla’s donation to OpenTelemetry**

The proposed
[donation of Beyla to OpenTelemetry](https://github.com/open-telemetry/community/issues/2406)
presents an opportunity to enhance OpenTelemetry’s eBPF-based
auto-instrumentation capabilities. If accepted, this donation will help
expand support for additional signals, protocols, and languages, creating a
more comprehensive eBPF-based observability solution. OpenTelemetry Go
Auto-Instrumentation will evolve alongside these developments, ensuring
seamless collaboration while continuing to provide robust tracing for Go
applications.

Keep track of our progress in the
[2025 Goals tracking issue](https://github.com/open-telemetry/opentelemetry-go-instrumentation/issues/1659).

## Join the journey

As with all OpenTelemetry projects, the success of Go Auto-Instrumentation
depends on the community. Whether you’re a developer interested in contributing,
a company looking to adopt the project, or simply curious about observability,
we’d love for you to join us.

Here’s how you can get involved:

- **Try the beta**: Integrate the project into your applications and
[provide feedback](https://github.com/open-telemetry/opentelemetry-go-instrumentation/discussions/1697).
- **Contribute**: Check out
[open issues](https://github.com/open-telemetry/opentelemetry-go-instrumentation/issues)
and
[contribute](https://github.com/open-telemetry/opentelemetry-go-instrumentation/blob/0ebb7f21116bfdd8e29c315efdbf359cd74bddac/CONTRIBUTING.md)
to the project on
[GitHub](https://github.com/open-telemetry/opentelemetry-go-instrumentation).
- **Join the discussion**: Participate in our
[SIG meetings](https://groups.google.com/a/opentelemetry.io/g/calendar-go) and
discussions on [Slack](https://cloud-native.slack.com/archives/C03S01YSAS0).

## Acknowledgments

This beta release is the result of countless hours of work by contributors from
around the world. Thank you to everyone who has contributed code, documentation,
feedback, and enthusiasm to make this milestone possible.
40 changes: 40 additions & 0 deletions static/refcache.json
Original file line number Diff line number Diff line change
Expand Up @@ -1827,6 +1827,10 @@
"StatusCode": 200,
"LastSeen": "2024-10-24T15:10:31.184402+02:00"
},
"https://cloud-native.slack.com/archives/C03S01YSAS0": {
"StatusCode": 200,
"LastSeen": "2025-01-29T17:30:33.389601601Z"
},
"https://cloud-native.slack.com/archives/C0422FSELH0": {
"StatusCode": 200,
"LastSeen": "2024-08-09T10:45:38.976435-04:00"
Expand Down Expand Up @@ -6559,6 +6563,10 @@
"StatusCode": 206,
"LastSeen": "2025-01-18T20:45:29.87596Z"
},
"https://github.com/open-telemetry/community/issues/2406": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:15.084501808Z"
},
"https://github.com/open-telemetry/community/issues/2497": {
"StatusCode": 206,
"LastSeen": "2025-01-18T20:45:32.577654Z"
Expand Down Expand Up @@ -8983,10 +8991,34 @@
"StatusCode": 200,
"LastSeen": "2024-08-09T10:44:15.667174-04:00"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/blob/0ebb7f21116bfdd8e29c315efdbf359cd74bddac/CONTRIBUTING.md": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:28.598163793Z"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/blob/main/docs/getting-started.md": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:06.908079743Z"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/blob/main/docs/how-it-works.md": {
"StatusCode": 206,
"LastSeen": "2025-01-16T11:37:46.811839-05:00"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/discussions/1697": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:21.969390623Z"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/issues": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:25.012053984Z"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/issues/1659": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:18.099406688Z"
},
"https://github.com/open-telemetry/opentelemetry-go-instrumentation/tree/0ebb7f21116bfdd8e29c315efdbf359cd74bddac/examples/rolldice": {
"StatusCode": 206,
"LastSeen": "2025-01-29T17:30:12.02761941Z"
},
"https://github.com/open-telemetry/opentelemetry-go-vanityurls": {
"StatusCode": 200,
"LastSeen": "2024-08-23T20:33:46.750242014Z"
Expand Down Expand Up @@ -17075,6 +17107,10 @@
"StatusCode": 200,
"LastSeen": "2024-08-12T17:56:07.964057+02:00"
},
"https://pkg.go.dev/github.com/segmentio/kafka-go": {
"StatusCode": 200,
"LastSeen": "2025-01-29T17:30:03.308377379Z"
},
"https://pkg.go.dev/go.opentelemetry.io/collector/cmd/builder": {
"StatusCode": 200,
"LastSeen": "2024-03-01T16:49:30.684687+01:00"
Expand Down Expand Up @@ -17347,6 +17383,10 @@
"StatusCode": 200,
"LastSeen": "2024-01-30T15:25:12.45117-05:00"
},
"https://pkg.go.dev/google.golang.org/grpc": {
"StatusCode": 200,
"LastSeen": "2025-01-29T17:30:01.456756939Z"
},
"https://pkg.go.dev/google.golang.org/grpc/credentials#PerRPCCredentials": {
"StatusCode": 200,
"LastSeen": "2025-01-06T11:32:36.518761-05:00"
Expand Down

0 comments on commit 140ad81

Please sign in to comment.