全部产品
Search
文档中心

Application Real-Time Monitoring Service:Komponen dan framework Go yang didukung oleh Pemantauan Aplikasi ARMS

更新时间:Feb 05, 2026

Topik ini mencantumkan persyaratan sistem operasi dan arsitektur untuk pemantauan aplikasi Go, serta komponen dan framework pihak ketiga yang didukung oleh ARMS.

Persyaratan sistem operasi

Nama kompiler

Sistem operasi

Arsitektur

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

Versi Go yang didukung

Versi 1.18 atau lebih baru

Versi plugin yang didukung

Message

Komponen

Alamat repositori

Versi minimum

Versi lebih tinggi

AMQP

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

v1.4.0

v1.10.0

Segmentio Kafka

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

v0.4.10

v0.4.49

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.3

IBM Sarama

https://github.com/IBM/sarama

v1.22.0

v1.46.3

Shopify Sarama

https://github.com/Shopify/sarama

v1.22.0

v1.38.1

Mqtt Server

https://github.com/mochi-mqtt/server

v2.6.0

No limit

franz-go

https://github.com/twmb/franz-go

v1.18.0

No limit

confluent-kafka-go

https://github.com/confluentinc/confluent-kafka-go

v1.7.0

No limit

streadway-amqp

https://github.com/streadway/amqp

v1.0.0

No limit

Framework RPC

Komponen

Alamat Repositori

Versi minimum

Later versions

Beego

https://github.com/beego/beego

v1.2.0

No limit

Dubbo

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

v3.0.1

v3.3.0

Echo

https://github.com/labstack/echo

v4.0.0

No limit

FastHTTP

https://github.com/valyala/fasthttp

v1.45.0

No limit

Fiber

https://github.com/gofiber/fiber

v2.43.0

No limit

Gin

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

v1.7.0

No limit

GoFrame

https://github.com/gogf/gf

v2.4.0

No limit

Go Micro

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

v4.9.0

v5.12.0

Go Restful

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

v3.7.0

No limit

Go Zero

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

v1.5.0

No limit

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

No limit

Kratos

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

v2.1.2

v2.9.2

Macaron

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

v1.1.0

No limit

Mux

https://github.com/gorilla/mux

v1.3.0

No limit

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.3

Rpcx

https://github.com/smallnest/rpcx

v1.9.0

No limit

SQL dan NoSQL

Komponen

Repository Address

Versi minimum

Later versions

Go Elasticsearch

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

v7.0.0

No limit

Go Redis

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

v8.10.0

No limit

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.31.1

GORM MySQL

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

v1.0.4

No limit

MySQL driver di pustaka standar Go

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

v1.18

Tidak ada batas

Mongo

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

v1.11.1

No limit

PostgreSQL

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

v10.10.0

v10.15.0

Redis Go

https://github.com/gomodule/redigo

v1.9.0

v1.9.3

Rueidis

https://github.com/redis/rueidis

v1.0.30

No limit

sqlx

https://github.com/jmoiron/sqlx

v1.3.0

v1.4.0

Xorm

https://github.com/go-xorm

v0.2.2

No limit

ClickHouse

https://github.com/ClickHouse/clickhouse-go

v2.0.1

Tidak ada batas

GORM ClickHouse

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

v0.2.0

No limit

Logging

Komponen

Alamat repositori

Versi minimum

Versi lebih tinggi

Gokit Log

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

v0.1.0

v0.2.1

Zerolog

https://github.com/rs/zerolog

v1.10.0

No limit

Zap

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

v1.13.0

No limit

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

go-zero logx

https://github.com/zeromicro/go-zero/tree/master/core/logx

v1.6.5

No limit

Kratos log

https://github.com/go-kratos/kratos/blob/main/middleware/logging

v2.1.2

v2.4.0

Penjadwalan tugas

Komponen

Repository Address

Minimum version

Versi Lebih Tinggi

Cron

https://github.com/robfig/cron

v3.0.0

No limit

XxlJob

https://github.com/xxl-job/xxl-job-executor-go

v1.2.0

Tidak ada batas

Trace SDK

Komponen

Alamat Repositori

Versi Sebelumnya

Versi Lanjutan

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.39.0

AI SDK

Komponen

Repository Address

Versi minimum

Versi Lanjutan

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

openai-go

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

v1.5.0

No limit

go-openai

https://github.com/sashabaranov/go-openai

v1.30.0

No limit

deepseek

https://github.com/cohesion-org/deepseek-go

v1.3.0

No limit

coze-studio

https://github.com/coze-dev/coze-studio

v0.2.0

No limit

Alibaba Cloud SDK

Komponen

Repository Address

Versi minimum

Versi selanjutnya

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

SDK Lainnya

Component

Alamat Repositori

Versi sebelumnya

Versi selanjutnya

ants pool

https://github.com/panjf2000/ants

v1.1.0

No limit

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.22.4

FAQ

Mengapa terjadi putus koneksi saat menggunakan framework message?

Karena batasan implementasi pada beberapa framework message, agen Go saat ini memiliki keterbatasan dalam propagasi konteks jejak (trace context). Berikut daftarnya.

Komponen

Alamat Repositori

Producer

Consumer

AMQP

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

No limit.

Hanya rentang Receive yang dikumpulkan. Rentang yang dihasilkan dari panggilan downstream yang dipicu oleh konten pesan tidak dapat ditautkan ke rentang Receive.

Segmentio Kafka

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

No limit.

Hanya rentang Receive yang dikumpulkan. Rentang yang dihasilkan dari panggilan downstream yang dipicu oleh konten pesan tidak dapat ditautkan ke rentang Receive.

Shopify Sarama

https://github.com/IBM/sarama

Saat menggunakan AsyncProducer, rentang Publish tidak dapat ditautkan ke rentang induknya.

Hanya rentang Receive yang dikumpulkan. Rentang yang dihasilkan dari panggilan downstream yang dipicu oleh konten pesan tidak dapat ditautkan ke rentang Receive.

IBM Sarama

https://github.com/IBM/sarama

Saat menggunakan AsyncProducer, rentang Publish tidak dapat ditautkan ke rentang induknya.

Hanya rentang Receive yang dikumpulkan. Rentang yang dihasilkan dari panggilan downstream yang dipicu oleh konten pesan tidak dapat ditautkan ke rentang Receive.

RocketMQ Client Go

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

No limit.

  • Hanya PushConsumer yang didukung.

  • Untuk konsumsi batch beberapa pesan, jika terjadi panggilan downstream selama pemrosesan, semua rentang downstream akan menempel pada pesan terakhir dalam batch tersebut. Masalah ini tidak terjadi pada konsumsi pesan tunggal.

RocketMQ Client

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

No limit.

Hanya rentang Receive yang dikumpulkan. Rentang yang dihasilkan dari panggilan downstream yang dipicu oleh konten pesan tidak dapat ditautkan ke rentang Receive.

Mengapa saya tidak melihat panggilan database atau NoSQL di Konsol saat menggunakan client Redis?

Agen Go tidak dapat menginstrumentasi aksi yang terjadi sebelum fungsi init dijalankan.

Anda dapat menginisialisasi client Redis atau database lainnya dalam fungsi init.

// Tidak valid
var rdb = redis.NewClient(&redis.Options{
	Addr:     "localhost:6379",
	Password: "", // tidak ada password yang disetel
	DB:       0,  // gunakan DB default
})

// Valid
var rdb *redis.Client

func init() {
	rdb = redis.NewClient(&redis.Options{
		Addr:     "localhost:6379",
		Password: "", // tidak ada password yang disetel
		DB:       0,  // gunakan DB default
	})
}

Mengapa saya tidak melihat instrumentasi OpenTelemetry SDK kustom?

  1. Di halaman Konfigurasi kustom, di bawah Pengaturan switch agen, pilih opentelemetry-plugin. Kemudian, restart aplikasi Anda.

    image

  2. Laju pengambilan sampel (sampling rate) default adalah 10%. Dengan volume permintaan rendah, jejak mungkin tidak muncul. Anda dapat meningkatkan laju pengambilan sampel tersebut.

Bagaimana cara menambahkan span kustom untuk RabbitMQ?

Contoh kode berikut menambahkan Span kustom:

import (
    "context"
    oTrace "go.opentelemetry.io/otel/trace"
    "go.opentelemetry.io/otel/propagation"
    "go.opentelemetry.io/otel"
    "go.opentelemetry.io/otel/trace"
  )
  
  // Buat span untuk setiap pesan di handler.
  func handle(deliveries <-chan amqp.Delivery, done chan error) {
      cleanup := func() {
          Log.Printf("handle: saluran deliveries ditutup")
          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()
        // proses lainnya
      }
  }
  
  

Bagaimana cara menambahkan span kustom untuk Kafka?

Kode contoh berikut menunjukkan cara menambahkan Span kustom:

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"
  )
  
  // Buat span untuk setiap pesan di 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)
              tracer := otel.GetTracerProvider().Tracer("")
              opts := append([]oTrace.SpanStartOption{}, oTrace.WithSpanKind(oTrace.SpanKindConsumer))
              ctx, span := tracer.Start(ctx, "mq", opts...)
              defer span.End()
              // proses lainnya
          }
  
      }
  }