1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
package server
import (
"context"
"time"
"gitlab.com/gitlab-org/cluster-integration/gitlab-agent/v16/internal/module/agent_tracker"
"gitlab.com/gitlab-org/cluster-integration/gitlab-agent/v16/internal/module/agent_tracker/rpc"
"gitlab.com/gitlab-org/cluster-integration/gitlab-agent/v16/internal/module/modserver"
"gitlab.com/gitlab-org/cluster-integration/gitlab-agent/v16/internal/module/modshared"
otelmetric "go.opentelemetry.io/otel/metric"
)
type Factory struct {
AgentQuerier agent_tracker.Querier
}
func (f *Factory) New(config *modserver.Config) (modserver.Module, error) {
_, err := config.Meter.Int64ObservableGauge(
"connected_agents_count",
otelmetric.WithDescription("The number of unique connected agents"),
otelmetric.WithInt64Callback(f.connectedAgents),
)
if err != nil {
return nil, err
}
rpc.RegisterAgentTrackerServer(config.APIServer, &server{
agentQuerier: f.AgentQuerier,
})
return &modserver.NopModule{
ModuleName: agent_tracker.ModuleName,
}, nil
}
func (f *Factory) Name() string {
return agent_tracker.ModuleName
}
func (f *Factory) StartStopPhase() modshared.ModuleStartStopPhase {
return modshared.ModuleStartBeforeServers
}
func (f *Factory) connectedAgents(ctx context.Context, observer otelmetric.Int64Observer) error {
ctx, cancel := context.WithTimeout(ctx, time.Second)
defer cancel()
size, err := f.AgentQuerier.GetConnectedAgentsCount(ctx)
if err != nil {
return err
}
observer.Observe(size)
return nil
}
|