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"
"math"
"time"
"github.com/prometheus/client_golang/prometheus"
"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"
"gitlab.com/gitlab-org/cluster-integration/gitlab-agent/v16/internal/tool/metric"
)
type Factory struct {
AgentQuerier agent_tracker.Querier
}
func (f *Factory) New(config *modserver.Config) (modserver.Module, error) {
rpc.RegisterAgentTrackerServer(config.ApiServer, &server{
agentQuerier: f.AgentQuerier,
})
connectedAgentsCountGaugeFunc := f.constructConnectedAgentsCountGaugeFunc()
err := metric.Register(config.Registerer, connectedAgentsCountGaugeFunc)
if err != nil {
return nil, err
}
return &module{}, nil
}
func (f *Factory) Name() string {
return agent_tracker.ModuleName
}
func (f *Factory) StartStopPhase() modshared.ModuleStartStopPhase {
return modshared.ModuleStartBeforeServers
}
func (f *Factory) constructConnectedAgentsCountGaugeFunc() prometheus.GaugeFunc {
return prometheus.NewGaugeFunc(prometheus.GaugeOpts{
Name: "connected_agents_count",
Help: "The number of unique connected agents",
}, func() float64 {
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
size, err := f.AgentQuerier.GetConnectedAgentsCount(ctx)
if err != nil {
return math.NaN()
}
return float64(size)
},
)
}
|