The integration package is used to support Go monitoring. Once you import this package into your Instana environment, you will be able to monitor Go runtime and the applications on various aspects by checking the dashboards, alerts, etc. included in this
npm install @instana-integration/goThe Instana integration package used to support Go monitoring. Once you import this package into your Instana environment, you will be able to monitor Go runtime and the applications on various aspects by checking the dashboards, alerts, etc. included in this integration package.
Below are the dashboards that are currently supported by this integration package.
| Dashboard Title | Description |
|-----------------------|---------------------------------------------------------------------------|
| Go Runtime Metrics | Instana custom dashboard that displays runtime metrics for Go application |
The Go runtime metrics are obtained by OpenTelemetry auto-instrumentation:
```
import "go.opentelemetry.io/contrib/instrumentation/runtime"
err := runtime.Start(runtime.WithMinimumReadMemStatsInterval(time.Second))
if err != nil {
log.Fatal(err)
}
Below are the Go runtime metrics that are currently supported by this integration package.
| Metrics Name | Description | Unit |
|-------------------------------------|----------------------|--------|
| process.runtime.go.mem.heap_inuse | Heap used | Number |
| process.runtime.go.mem.heap.alloc | Allocated memory | Byte |
| process.runtime.go.mem.heap.sys | System heap | Byte |
| process.runtime.go.mem.heap.inuse | Used heap | Byte |
| process.runtime.go.mem.heap.objects | Objects | Byte |
| process.runtime.go.goroutines | Executed goroutines | Number |
Below are the resource attributes that are currently supported by this integration package.
| Attribute Key | Type | Description |
|----------------------|---------|--------------------------------------------------------------------------|
| service.name | string | This attribute is used to describe the entity name. |
| service.instance.id | string | This attribute is used to describe the entity ID of the current object. |
Below are the events that are currently supported by this integration package.
Note: In each event definition, conditionValue represents a threshold used to trigger the event and is provided as a default or reference value. Please adjust this value based on your specific environment.
| Event Name | Description |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Context Deadline Exceeded Errors | Detects when Go applications are experiencing a high rate of context deadline exceeded errors, which may indicate timeouts in API calls, database operations, or other time-sensitive operations. |
| Go Heap Allocation Spike | Detects sudden spikes in heap allocations in Go applications, which may indicate inefficient memory usage patterns or unexpected workload increases. |
| High CPU Utilization in Go Application | Detects when a Go application is consuming an unusually high amount of CPU resources, which may indicate inefficient code, infinite loops, or excessive processing. |
| High Goroutine Count | Detects when a Go application has an unusually high number of goroutines, which may indicate goroutine leaks or excessive concurrency. |
| High Go Heap Usage | Detects when a Go application's heap usage is high relative to the system heap, which may indicate memory issues or leaks. |
| HTTP Connection Pool Exhaustion | Detects when a Go application's HTTP connection pool is nearing exhaustion, which may lead to connection timeouts and degraded performance for outgoing HTTP requests. |
| Go Memory Leak Detection | Detects potential memory leaks in Go applications by monitoring continuously increasing heap object count over time. |
With Instana CLI for integration package management, you can manage the lifecycle of this package such as downloading the package and importing it into Instana.
Downloading the package:
`shell`
$ stanctl-integration download --package @instana-integration/go
Importing the package into Instana:
`shell``
$ stanctl-integration import --package @instana-integration/go \
--server $INSTANA_SERVER \
--token $API_TOKEN \
--set servicename=$SERVICE_NAME \
--set serviceinstanceid=$SERVICE_INSTANCE_ID
- INSTANA_SERVER: This is the base URL of an Instana tenant unit, e.g. https://test-example.instana.io, which is used by the CLI to communicate with Instana server for package lifecycle management.
- API_TOKEN: Requests against the Instana API require valid API tokens. The API token can be generated via the Instana user interface. For more information, please refers to Instana documentation.
- SERVICE_NAME: Logical name of the service.
- SERVICE_INSTANCE_ID: The string ID of the service instance. The ID helps to distinguish instances of the same service that exist at the same time (e.g. instances of a horizontally scaled service).