Instrumenting Go Serverless Applications Using the Datadog Forwarder
Overview
Required setup
If not already configured:
After you have installed the AWS integration and the Datadog Forwarder, follow these steps to instrument your application to send metrics, logs, and traces to Datadog.
Configuration
Install
Install the Datadog Lambda library locally by running the following command:
go get github.com/DataDog/datadog-lambda-go
Instrument
Follow these steps to instrument the function:
Set environment variable DD_FLUSH_TO_LOG
and DD_TRACE_ENABLED
to true
.
Import the required packages in the file declaring your Lambda function handler.
package main
import (
"github.com/aws/aws-lambda-go/lambda"
"github.com/DataDog/datadog-lambda-go"
"gopkg.in/DataDog/dd-trace-go.v1/ddtrace/tracer" // 1.x
// "github.com/DataDog/dd-trace-go/v2/ddtrace/tracer" // 2.x
httptrace "gopkg.in/DataDog/dd-trace-go.v1/contrib/net/http" // 1.x
// httptrace "github.com/DataDog/dd-trace-go/contrib/net/http/v2" // 2.x
)
Wrap your Lambda function handler using the wrapper provided by the Datadog Lambda library.
func main() {
// Wrap your lambda handler like this
lambda.Start(ddlambda.WrapHandler(myHandler, nil))
/* OR with manual configuration options
lambda.Start(ddlambda.WrapHandler(myHandler, &ddlambda.Config{
BatchInterval: time.Second * 15
APIKey: "my-api-key",
}))
*/
}
Use the included libraries to create additional spans, connect logs and traces, and pass trace context to other services.
func myHandler(ctx context.Context, event MyEvent) (string, error) {
// Trace an HTTP request
req, _ := http.NewRequestWithContext(ctx, "GET", "https://www.datadoghq.com", nil)
client := http.Client{}
client = *httptrace.WrapClient(&client)
client.Do(req)
// Connect your Lambda logs and traces
currentSpan, _ := tracer.SpanFromContext(ctx)
log.Printf("my log message %v", currentSpan)
// Create a custom span
s, _ := tracer.StartSpanFromContext(ctx, "child.span")
time.Sleep(100 * time.Millisecond)
s.Finish()
}
Subscribe
Subscribe the Datadog Forwarder Lambda function to each of your function’s log groups, in order to send metrics, traces, and logs to Datadog.
- Install the Datadog Forwarder if you haven’t.
- Subscribe the Datadog Forwarder to your function’s log groups.
Tag
Although it’s optional, Datadog recommends tagging your serverless applications with the env
, service
, and version
tags for unified service tagging.
Explore
After configuring your function following the steps above, view your metrics, logs, and traces on the Serverless homepage.
Monitor custom business logic
If you would like to submit a custom metric, see the sample code below:
package main
import (
"github.com/aws/aws-lambda-go/lambda"
"github.com/DataDog/datadog-lambda-go"
)
func main() {
// Wrap your handler function
lambda.Start(ddlambda.WrapHandler(myHandler, nil))
}
func myHandler(ctx context.Context, event MyEvent) (string, error) {
// Submit a custom metric
ddlambda.Metric(
"coffee_house.order_value", // Metric name
12.45, // Metric value
"product:latte", "order:online" // Associated tags
)
// Submit a custom metric with timestamp
ddlambda.MetricWithTimestamp(
"coffee_house.order_value", // Metric name
12.45, // Metric value
time.Now(), // Timestamp, must be within last 20 mins
"product:latte", "order:online" // Associated tags
)
req, err := http.NewRequest("GET", "http://example.com/status")
// Add the datadog distributed tracing headers
ddlambda.AddTraceHeaders(ctx, req)
client := http.Client{}
client.Do(req)
}
Learn more about custom metric submission.
Further Reading
Additional helpful documentation, links, and articles: