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_LOGandDD_TRACE_ENABLEDtotrue.
- Import the required packages in the file declaring your Lambda function handler. Note: This documentation uses v2 of the Go tracer, which Datadog recommends for all users. If you are using v1, see the migration guide to upgrade to v2.
```go
package main
import (
  "github.com/aws/aws-lambda-go/lambda"
  "github.com/DataDog/datadog-lambda-go"
  "github.com/DataDog/dd-trace-go/v2/ddtrace/tracer"
  httptrace "github.com/DataDog/dd-trace-go/contrib/net/http/v2"
)
```
- 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: