All Products
Search
Document Center

Cloud Monitor:Go components and frameworks supported by ARMS Application Monitoring

Last Updated:Sep 05, 2025

This topic describes the operating system and architecture requirements for Go application monitoring and lists the supported third-party components and frameworks.

Operating system requirements

Compiler name

Operating system

Architecture

instgo_linux_amd64

Linux

amd64

instgo_linux_arm64

Linux

arm64

instgo_darwin_amd64

Darwin

amd64

instgo_darwin_arm64

Darwin

arm64

instgo_windows_amd64.exe

Windows

amd64

Supported Go versions

1.18 and later

Supported plugin versions

Messaging

Component

Repository address

Minimum version

Maximum version

AMQP

https://github.com/rabbitmq/amqp091-go

v1.9.0

v1.10.0

Segmentio Kafka

https://github.com/segmentio/kafka-go

v0.4.10

v0.4.48

RocketMQ Client Go

https://github.com/apache/rocketmq-client-go

v2.1.0

v2.1.2

RocketMQ Client

https://github.com/apache/rocketmq-clients/tree/master/golang

v5.0.0

v5.1.2

IBM Sarama

https://github.com/IBM/sarama

v1.22.0

v1.45.2

Shopify Sarama

https://github.com/Shopify/sarama

v1.22.0

v1.38.1

RPC frameworks

Component

Repository address

Minimum version

Maximum version

Beego

https://github.com/beego/beego

v1.2.0

v2.3.8

Dubbo

https://github.com/apache/dubbo-go

v3.0.1

v3.3.0

Echo

https://github.com/labstack/echo

v4.0.0

v4.13.4

FastHTTP

https://github.com/valyala/fasthttp

v1.45.0

v1.65.0

Fiber

https://github.com/gofiber/fiber

v2.43.0

v2.52.8

Gin

https://github.com/gin-gonic/gin

v1.7.0

No limit

GoFrame

https://github.com/gogf/gf

v2.4.0

v2.9.0

Go Micro

https://github.com/go-micro/go-micro

v4.9.0

v5.3.1

Go Restful

https://github.com/emicklei/go-restful

v3.7.0

v3.12.1

Go Zero

https://github.com/zeromicro/go-zero

v1.5.0

v1.9.0

gRPC

https://github.com/grpc/grpc-go

v1.44.0

No limit

Iris

https://github.com/kataras/iris

v12.0.0

v12.2.11

Kitex

https://github.com/cloudwego/kitex

v0.5.1

v0.14.1

Kratos

https://github.com/go-kratos/kratos

v2.1.2

v2.8.4

Macaron

https://github.com/go-macaron/macaron

v1.1.0

v1.5.0

Mux

https://github.com/gorilla/mux

v1.3.0

v1.8.1

Net/HTTP

https://pkg.go.dev/net/http

v1.18

No limit

Thrift

https://github.com/apache/thrift/tree/master/lib/go

v0.19.0

v0.20.0

Hertz

https://github.com/cloudwego/hertz

v0.8.0

v0.10.2

SQL/NoSQL

Component

Repository address

Minimum version

Maximum version

Go Elasticsearch

https://github.com/elastic/go-elasticsearch

v8.0.0

v8.18.1

Go Redis

https://github.com/redis/go-redis

v8.10.0

v9.11.0

Go SQL Driver

https://github.com/go-sql-driver/mysql

v1.4.0

v1.9.3

Gorm

https://github.com/go-gorm/gorm

v1.20.12

v1.30.0

GORM MySQL

https://github.com/go-gorm/mysql

v1.0.4

v1.5.7

Go standard library database/sql

https://pkg.go.dev/database/sql

v1.18

v1.24

Mongo

https://github.com/mongodb/mongo-go-driver

v1.11.1

v1.17.3

PostgreSQL

https://github.com/go-pg/pg

v10.10.0

v10.14.0

Redis Go

https://github.com/gomodule/redigo

v1.9.0

v1.9.2

Logging

Component

Repository address

Minimum version

Maximum version

Gokit Log

https://github.com/go-kit/log

v0.1.0

v0.2.1

Zerolog

https://github.com/rs/zerolog

v1.10.0

v1.34.0

Zap

https://github.com/uber-go/zap

v1.13.0

v1.27.0

Logrus

https://github.com/sirupsen/logrus

v1.5.0

No limit

Log

https://pkg.go.dev/log

v1.21

No limit

Slog

https://pkg.go.dev/log/slog

v1.21

No limit

Task scheduling

Component

Repository address

Minimum version

Maximum version

Cron

https://github.com/robfig/cron

v3.0.0

No limit

Trace SDKs

Component

Repository address

Minimum version

Maximum version

OpenTracing SDK

https://github.com/opentracing/opentracing-go

v1.1.0

v1.2.0

OpenTelemetry SDK

https://github.com/open-telemetry/opentelemetry-go

v1.6.0

v1.37.0

AI SDKs

Component

Repository address

Minimum version

Maximum version

Dify Sandbox

https://github.com/langgenius/dify-sandbox

v0.2.0

No limit

Dify Plugin Daemon

https://github.com/langgenius/dify-plugin-daemon

v0.0.6

No limit

MCP SDK

https://github.com/mark3labs/mcp-go

v0.20.0

No limit

Langchain SDK

https://github.com/tmc/langchaingo

v0.1.0

No limit

Alibaba Cloud SDKs

Component

Repository address

Minimum version

Maximum version

FC Go SDK

https://github.com/aliyun/fc-runtime-go-sdk

v0.2.9

v0.3.1

OTS Go SDK

https://github.com/aliyun/aliyun-tablestore-go-sdk

v1.5.0

No limit

Other SDKs

Component

Repository address

Minimum version

Maximum version

K8s Client

https://github.com/kubernetes/client-go

v0.27.0

v0.32.3

K8s Controller Runtime

https://github.com/kubernetes-sigs/controller-runtime

v0.13.1

v0.18.7

FAQ

Why are traces broken when I use a messaging framework?

Because of implementation details in some messaging frameworks, the Go agent has limitations when propagating the trace context. The limitations are as follows:

Component

Repository address

Producer

Consumer

AMQP

https://github.com/rabbitmq/amqp091-go

No limitations.

Only Receive spans are collected. Spans created by downstream calls based on the message content cannot be linked to the Receive span.

Segmentio Kafka

https://github.com/segmentio/kafka-go

No limitations.

Only Receive spans are collected. Spans created by downstream calls based on the message content cannot be linked to the Receive span.

Shopify Sarama

https://github.com/IBM/sarama

When you use AsyncProducer, the Publish span cannot be linked to its parent call span.

Only Receive spans are collected. Spans created by downstream calls based on the message content cannot be linked to the Receive span.

IBM Sarama

https://github.com/IBM/sarama

When you use AsyncProducer, the Publish span cannot be linked to its parent call span.

Only Receive spans are collected. Spans created by downstream calls based on the message content cannot be linked to the Receive span.

RocketMQ Client Go

https://github.com/apache/rocketmq-client-go

No limitations.

  • Only PushConsumer is supported.

  • If multiple messages are consumed at once and a downstream service is called, the spans for the downstream calls are all attached to the span of the last message in the batch. This issue does not occur when consuming a single message at a time.

RocketMQ Client

https://github.com/apache/rocketmq-clients/tree/master/golang

No limitations.

Only Receive spans are collected. Spans created by downstream calls based on the message content cannot be linked to the Receive span.

Why can't I see database/NoSQL calls in the console when I use a Redis client?

Because of framework-specific implementations, the Go agent cannot effectively instrument actions that are executed before the init function.

Initialize the Redis client or database client in the init function.

// Invalid code
var rdb = redis.NewClient(&redis.Options{
	Addr:     "localhost:6379",
	Password: "", // no password set
	DB:       0,  // use default DB
})

// Valid code
var rdb *redis.Client

func init() {
	rdb = redis.NewClient(&redis.Options{
		Addr:     "localhost:6379",
		Password: "", // no password set
		DB:       0,  // use default DB
	})
}

Why can't I see my custom OTel SDK instrumentation?

  1. On the Custom Configurations page, select opentelemetry-plugin in the Probe switch settings section. Then, restart the application.

    image

  2. The default sample rate is 10%. If you have a low volume of requests, you might not see any data. You can adjust the sample rate as needed.

How do I add a custom span for RabbitMQ?

The following code sample shows how to add a custom span:

import (
    "context"
    oTrace "go.opentelemetry.io/otel/trace"
    "go.opentelemetry.io/otel/propagation"
    "go.opentelemetry.io/otel"
    "go.opentelemetry.io/otel/trace"
  )
  
  // Create a span for each message in the message handler.
  func handle(deliveries <-chan amqp.Delivery, done chan error) {
      cleanup := func() {
          Log.Printf("handle: deliveries channel closed")
          done <- nil
      }
  
      defer cleanup()
      for d := range deliveries {
        var headerMap propagation.MapCarrier
        headerMap = make(map[string]string)
        headerMap["traceparent"] = delivery.Headers["traceparent"]
        ctx := otel.GetTextMapPropagator().Extract(context.Background(), headerMap)
        ctx = oTrace.ContextWithSpanContext(context.Background(), oTrace.SpanFromContext(ctx).SpanContext())
        tracer = otel.GetTracerProvider().Tracer("")
        opts := append([]oTrace.SpanStartOption{}, oTrace.WithSpanKind(oTrace.SpanKindConsumer))
        ctx, span := tracer.Start(context.Background(), "mq", opts...)
        defer span.End()
        //other process
      }
  }
  
  

How do I add a custom span for Kafka?

The following code sample shows how to add a custom span:

import (
    kafka "github.com/segmentio/kafka-go"
      "go.opentelemetry.io/otel"
      "go.opentelemetry.io/otel/propagation"
      "go.opentelemetry.io/otel/trace"
      oTrace "go.opentelemetry.io/otel/trace"
  )
  
  // Create a span for each message in the message handler.
  func handle(msg kafka.Message) {
      for _, attr := range msg.Headers {
          if attr.Key == "traceparent" {
              var headerMap propagation.MapCarrier
              headerMap = make(map[string]string)
              headerMap["traceparent"] = string(attr.Value)
              ctx := otel.GetTextMapPropagator().Extract(context.Background(), headerMap)
              ctx = oTrace.ContextWithSpanContext(context.Background(), oTrace.SpanFromContext(ctx).SpanContext())
              tracer := otel.GetTracerProvider().Tracer("")
              opts := append([]oTrace.SpanStartOption{}, oTrace.WithSpanKind(oTrace.SpanKindConsumer))
              ctx, span := tracer.Start(context.Background(), "mq", opts...)
              defer span.End()
              //other process
          }
  
      }
  }