azure-container-networking/aitelemetry/api.go

71 строка
2.1 KiB
Go

package aitelemetry
import (
"sync"
"github.com/Azure/azure-container-networking/common"
"github.com/microsoft/ApplicationInsights-Go/appinsights"
)
// Application trace/log structure
type Report struct {
Message string
Context string
CustomDimensions map[string]string
}
// Application event structure
type Event struct {
EventName string
ResourceID string
Properties map[string]string
}
// Application metrics structure
type Metric struct {
Name string
Value float64
CustomDimensions map[string]string
}
type AIConfig struct {
AppName string
AppVersion string
BatchSize int
BatchInterval int
DisableMetadataRefreshThread bool
RefreshTimeout int
GetEnvRetryCount int
GetEnvRetryWaitTimeInSecs int
DebugMode bool
}
// TelmetryHandle holds appinsight handles and metadata
type telemetryHandle struct {
appName string
appVersion string
metadata common.Metadata
diagListener appinsights.DiagnosticsMessageListener
client appinsights.TelemetryClient
disableMetadataRefreshThread bool
refreshTimeout int
rwmutex sync.RWMutex
}
// Telemetry Interface to send metrics/Logs to appinsights
type TelemetryHandle interface {
// TrackLog function sends report (trace) to appinsights resource. It overrides few of the existing columns with app information
// and for rest it uses custom dimesion
TrackLog(report Report)
// TrackMetric function sends metric to appinsights resource. It overrides few of the existing columns with app information
// and for rest it uses custom dimesion
TrackMetric(metric Metric)
// TrackEvent function sends events to appinsights resource. It overrides a few of the existing columns
// with app information.
TrackEvent(aiEvent Event)
// Close - should be called for each NewAITelemetry call. Will release resources acquired
Close(timeout int)
// Flush - forces the current queue to be sent
Flush()
}