This guide explains how to configure a Go app using the Go OpenTelemetry SDK to send telemetry data to Axiom.
OpenTelemetry offers a single set of APIs and libraries that standardize how you collect and transfer telemetry data. This guide focuses on setting up OpenTelemetry in a Go app to send traces to Axiom.
main.go
sample below.First, run the following in your terminal to install the necessary Go packages:
This installs the OpenTelemetry Go SDK, the OTLP (OpenTelemetry Protocol) trace exporter, and other necessary packages for instrumentation and resource definition.
Before installing the OpenTelemetry dependencies, ensure your Go project is properly initialized as a module and all dependencies are correctly managed. This step is important for resolving import issues and managing your project’s dependencies effectively.
If your project is not already initialized as a Go module, run the following command in your project’s root directory. This step creates a go.mod
file which tracks your project’s dependencies.
Replace <module-name>
with your project’s name or the GitHub repository path if you plan to push the code to GitHub. For example, go mod init github.com/yourusername/yourprojectname
.
After initializing your Go module, tidy up your project’s dependencies. This ensures that your go.mod
file accurately reflects the packages your project depends on, including the correct versions of the OpenTelemetry libraries you’ll be using.
Run the following command in your project’s root directory:
This command will download the necessary dependencies and update your go.mod
and go.sum
files accordingly. It’s a good practice to run go mod tidy
after adding new imports to your project or periodically to keep dependencies up to date.
main.go
is the entry point of the app. It invokes InstallExportPipeline
from exporter.go
to set up the tracing exporter. It also sets up a basic HTTP server with OpenTelemetry instrumentation to demonstrate how telemetry data can be collected and exported in a simple web app context. It also demonstrates the usage of span links to establish relationships between spans across different traces.
exporter.go
is responsible for setting up the OpenTelemetry tracing exporter. It defines the resource attributes
, initializes
the tracer
, and configures the OTLP (OpenTelemetry Protocol) exporter with appropriate endpoints and headers, allowing your app to send telemetry data to Axiom.
To run the app, execute both exporter.go
and main.go
. Use the command go run main.go exporter.go
to start the app. Once your app is running, traces collected by your app are exported to Axiom. The server starts on the specified port, and you can interact with it by sending requests to the /rolldice
endpoint.
For example, if you are using port 8080
, your app will be accessible locally at http://localhost:8080/rolldice
. This URL will direct your requests to the /rolldice
endpoint of your server running on your local machine.
After deploying your app, you can log into your Axiom account to view and analyze the telemetry data. As you interact with your app, traces will be collected and exported to Axiom, where you can monitor and analyze your app’s performance and behavior.
Observing the Telemetry Data in Axiom image
This data can then be further viewed and analyzed in Axiom’s dashboard, providing insights into the performance and behavior of your app.
Dynamic OpenTelemetry Traces Dashboard Go
Manual instrumentation in Go involves managing spans within your code to track operations and events. This method offers precise control over what is instrumented and how spans are configured.
Use the OpenTelemetry API to obtain a tracer instance. This tracer will be used to start and manage spans.
Manually start spans before the operations you want to trace and ensure they are ended after the operations complete.
Enhance spans with additional information using attributes or events to provide more context about the traced operation.
Automatic instrumentation in Go uses libraries and integrations that automatically create spans for operations, simplifying the addition of observability to your app.
Use OpenTelemetry-contrib
libraries designed for automatic instrumentation of standard Go frameworks and libraries, such as net/http
.
Automatically instrument HTTP servers and clients by wrapping them with OpenTelemetry’s instrumentation. For HTTP servers, wrap your handlers with otelhttp.NewHandler
.
After setting up automatic instrumentation, no further changes are required for tracing standard operations. The instrumentation takes care of starting, managing, and ending spans.
Field Category | Field Name | Description |
---|---|---|
Unique Identifiers | ||
_rowid | Unique identifier for each row in the trace data. | |
span_id | Unique identifier for the span within the trace. | |
trace_id | Unique identifier for the entire trace. | |
Timestamps | ||
_systime | System timestamp when the trace data was recorded. | |
_time | Timestamp when the actual event being traced occurred. | |
HTTP Attributes | ||
attributes.custom[“http.host”] | Host information where the HTTP request was sent. | |
attributes.custom[“http.server_name”] | Server name for the HTTP request. | |
attributes.http.flavor | HTTP protocol version used. | |
attributes.http.method | HTTP method used for the request. | |
attributes.http.route | Route accessed during the HTTP request. | |
attributes.http.scheme | Protocol scheme (HTTP/HTTPS). | |
attributes.http.status_code | HTTP response status code. | |
attributes.http.target | Specific target of the HTTP request. | |
attributes.http.user_agent | User agent string of the client. | |
attributes.custom.user_agent.original | Original user agent string, providing client software and OS. | |
Network Attributes | ||
attributes.net.host.port | Port number on the host receiving the request. | |
attributes.net.peer.port | Port number on the peer (client) side. | |
attributes.custom[“net.peer.ip”] | IP address of the peer in the network interaction. | |
attributes.net.sock.peer.addr | Socket peer address, indicating the IP version used. | |
attributes.net.sock.peer.port | Socket peer port number. | |
attributes.custom.net.protocol.version | Protocol version used in the network interaction. | |
Operational Details | ||
duration | Time taken for the operation. | |
kind | Type of span (for example,, server, client). | |
name | Name of the span. | |
scope | Instrumentation scope. | |
service.name | Name of the service generating the trace. | |
service.version | Version of the service generating the trace. | |
Resource Attributes | ||
resource.environment | Environment where the trace was captured, for example,, production. | |
attributes.custom.http.wrote_bytes | Number of bytes written in the HTTP response. | |
Telemetry SDK Attributes | ||
telemetry.sdk.language | Language of the telemetry SDK (if previously not included). | |
telemetry.sdk.name | Name of the telemetry SDK (if previously not included). | |
telemetry.sdk.version | Version of the telemetry SDK (if previously not included). |
go.opentelemetry.io/otel
This is the core SDK for OpenTelemetry in Go. It provides the necessary tools to create and manage telemetry data (traces, metrics, and logs).
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp
This package allows your app to export telemetry data over HTTP using the OpenTelemetry Protocol (OTLP). It’s important for sending data to Axiom or any other backend that supports OTLP.
go.opentelemetry.io/otel/sdk/resource
and go.opentelemetry.io/otel/sdk/trace
These packages help define the properties of your telemetry data, such as service name and version, and manage trace data within your app.
go.opentelemetry.io/otel/semconv/v1.24.0
This package provides standardized schema URLs and attributes, ensuring consistency across different OpenTelemetry implementations.
go.opentelemetry.io/otel/trace
This package offers the API for tracing. It enables you to create spans, record events, and manage context propagation in your app.
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp
Used for instrumenting HTTP clients and servers. It automatically records data about HTTP requests and responses, which is essential for web apps.
go.opentelemetry.io/otel/propagation
This package provides the ability to propagate context and trace information across service boundaries.
This guide explains how to configure a Go app using the Go OpenTelemetry SDK to send telemetry data to Axiom.
OpenTelemetry offers a single set of APIs and libraries that standardize how you collect and transfer telemetry data. This guide focuses on setting up OpenTelemetry in a Go app to send traces to Axiom.
main.go
sample below.First, run the following in your terminal to install the necessary Go packages:
This installs the OpenTelemetry Go SDK, the OTLP (OpenTelemetry Protocol) trace exporter, and other necessary packages for instrumentation and resource definition.
Before installing the OpenTelemetry dependencies, ensure your Go project is properly initialized as a module and all dependencies are correctly managed. This step is important for resolving import issues and managing your project’s dependencies effectively.
If your project is not already initialized as a Go module, run the following command in your project’s root directory. This step creates a go.mod
file which tracks your project’s dependencies.
Replace <module-name>
with your project’s name or the GitHub repository path if you plan to push the code to GitHub. For example, go mod init github.com/yourusername/yourprojectname
.
After initializing your Go module, tidy up your project’s dependencies. This ensures that your go.mod
file accurately reflects the packages your project depends on, including the correct versions of the OpenTelemetry libraries you’ll be using.
Run the following command in your project’s root directory:
This command will download the necessary dependencies and update your go.mod
and go.sum
files accordingly. It’s a good practice to run go mod tidy
after adding new imports to your project or periodically to keep dependencies up to date.
main.go
is the entry point of the app. It invokes InstallExportPipeline
from exporter.go
to set up the tracing exporter. It also sets up a basic HTTP server with OpenTelemetry instrumentation to demonstrate how telemetry data can be collected and exported in a simple web app context. It also demonstrates the usage of span links to establish relationships between spans across different traces.
exporter.go
is responsible for setting up the OpenTelemetry tracing exporter. It defines the resource attributes
, initializes
the tracer
, and configures the OTLP (OpenTelemetry Protocol) exporter with appropriate endpoints and headers, allowing your app to send telemetry data to Axiom.
To run the app, execute both exporter.go
and main.go
. Use the command go run main.go exporter.go
to start the app. Once your app is running, traces collected by your app are exported to Axiom. The server starts on the specified port, and you can interact with it by sending requests to the /rolldice
endpoint.
For example, if you are using port 8080
, your app will be accessible locally at http://localhost:8080/rolldice
. This URL will direct your requests to the /rolldice
endpoint of your server running on your local machine.
After deploying your app, you can log into your Axiom account to view and analyze the telemetry data. As you interact with your app, traces will be collected and exported to Axiom, where you can monitor and analyze your app’s performance and behavior.
Observing the Telemetry Data in Axiom image
This data can then be further viewed and analyzed in Axiom’s dashboard, providing insights into the performance and behavior of your app.
Dynamic OpenTelemetry Traces Dashboard Go
Manual instrumentation in Go involves managing spans within your code to track operations and events. This method offers precise control over what is instrumented and how spans are configured.
Use the OpenTelemetry API to obtain a tracer instance. This tracer will be used to start and manage spans.
Manually start spans before the operations you want to trace and ensure they are ended after the operations complete.
Enhance spans with additional information using attributes or events to provide more context about the traced operation.
Automatic instrumentation in Go uses libraries and integrations that automatically create spans for operations, simplifying the addition of observability to your app.
Use OpenTelemetry-contrib
libraries designed for automatic instrumentation of standard Go frameworks and libraries, such as net/http
.
Automatically instrument HTTP servers and clients by wrapping them with OpenTelemetry’s instrumentation. For HTTP servers, wrap your handlers with otelhttp.NewHandler
.
After setting up automatic instrumentation, no further changes are required for tracing standard operations. The instrumentation takes care of starting, managing, and ending spans.
Field Category | Field Name | Description |
---|---|---|
Unique Identifiers | ||
_rowid | Unique identifier for each row in the trace data. | |
span_id | Unique identifier for the span within the trace. | |
trace_id | Unique identifier for the entire trace. | |
Timestamps | ||
_systime | System timestamp when the trace data was recorded. | |
_time | Timestamp when the actual event being traced occurred. | |
HTTP Attributes | ||
attributes.custom[“http.host”] | Host information where the HTTP request was sent. | |
attributes.custom[“http.server_name”] | Server name for the HTTP request. | |
attributes.http.flavor | HTTP protocol version used. | |
attributes.http.method | HTTP method used for the request. | |
attributes.http.route | Route accessed during the HTTP request. | |
attributes.http.scheme | Protocol scheme (HTTP/HTTPS). | |
attributes.http.status_code | HTTP response status code. | |
attributes.http.target | Specific target of the HTTP request. | |
attributes.http.user_agent | User agent string of the client. | |
attributes.custom.user_agent.original | Original user agent string, providing client software and OS. | |
Network Attributes | ||
attributes.net.host.port | Port number on the host receiving the request. | |
attributes.net.peer.port | Port number on the peer (client) side. | |
attributes.custom[“net.peer.ip”] | IP address of the peer in the network interaction. | |
attributes.net.sock.peer.addr | Socket peer address, indicating the IP version used. | |
attributes.net.sock.peer.port | Socket peer port number. | |
attributes.custom.net.protocol.version | Protocol version used in the network interaction. | |
Operational Details | ||
duration | Time taken for the operation. | |
kind | Type of span (for example,, server, client). | |
name | Name of the span. | |
scope | Instrumentation scope. | |
service.name | Name of the service generating the trace. | |
service.version | Version of the service generating the trace. | |
Resource Attributes | ||
resource.environment | Environment where the trace was captured, for example,, production. | |
attributes.custom.http.wrote_bytes | Number of bytes written in the HTTP response. | |
Telemetry SDK Attributes | ||
telemetry.sdk.language | Language of the telemetry SDK (if previously not included). | |
telemetry.sdk.name | Name of the telemetry SDK (if previously not included). | |
telemetry.sdk.version | Version of the telemetry SDK (if previously not included). |
go.opentelemetry.io/otel
This is the core SDK for OpenTelemetry in Go. It provides the necessary tools to create and manage telemetry data (traces, metrics, and logs).
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp
This package allows your app to export telemetry data over HTTP using the OpenTelemetry Protocol (OTLP). It’s important for sending data to Axiom or any other backend that supports OTLP.
go.opentelemetry.io/otel/sdk/resource
and go.opentelemetry.io/otel/sdk/trace
These packages help define the properties of your telemetry data, such as service name and version, and manage trace data within your app.
go.opentelemetry.io/otel/semconv/v1.24.0
This package provides standardized schema URLs and attributes, ensuring consistency across different OpenTelemetry implementations.
go.opentelemetry.io/otel/trace
This package offers the API for tracing. It enables you to create spans, record events, and manage context propagation in your app.
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp
Used for instrumenting HTTP clients and servers. It automatically records data about HTTP requests and responses, which is essential for web apps.
go.opentelemetry.io/otel/propagation
This package provides the ability to propagate context and trace information across service boundaries.