2021-03-16 11:14:56 +03:00
|
|
|
package metrics
|
|
|
|
|
2023-05-24 10:01:50 +03:00
|
|
|
import (
|
2023-10-04 10:03:37 +03:00
|
|
|
morphmetrics "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/morph/metrics"
|
2023-10-08 12:32:00 +03:00
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/util/logger"
|
2023-05-31 12:25:32 +03:00
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-observability/metrics"
|
2023-05-24 10:01:50 +03:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
)
|
2021-12-28 13:39:42 +03:00
|
|
|
|
2022-07-19 18:16:42 +03:00
|
|
|
type NodeMetrics struct {
|
2023-06-14 10:05:51 +03:00
|
|
|
engine *engineMetrics
|
|
|
|
state *stateMetrics
|
|
|
|
replicator *replicatorMetrics
|
|
|
|
objectService *objectServiceMetrics
|
|
|
|
treeService *treeServiceMetrics
|
|
|
|
epoch prometheus.Gauge
|
2023-06-07 17:06:02 +03:00
|
|
|
fstree *fstreeMetrics
|
2023-06-07 18:04:23 +03:00
|
|
|
blobstore *blobstoreMetrics
|
2023-08-18 11:14:10 +03:00
|
|
|
blobobvnizca *blobovnicza
|
2023-06-09 12:45:31 +03:00
|
|
|
metabase *metabaseMetrics
|
2023-06-09 16:19:47 +03:00
|
|
|
pilorama *piloramaMetrics
|
2023-08-09 09:23:03 +03:00
|
|
|
grpc *grpcServerMetrics
|
2023-10-04 19:20:59 +03:00
|
|
|
policer *policerMetrics
|
2023-10-04 10:03:37 +03:00
|
|
|
morphClient *morphClientMetrics
|
|
|
|
morphCache *morphCacheMetrics
|
2023-10-08 12:32:00 +03:00
|
|
|
log logger.LogMetrics
|
2021-03-16 11:14:56 +03:00
|
|
|
}
|
|
|
|
|
2022-07-19 18:16:42 +03:00
|
|
|
func NewNodeMetrics() *NodeMetrics {
|
|
|
|
return &NodeMetrics{
|
2023-06-07 18:04:23 +03:00
|
|
|
objectService: newObjectServiceMetrics(),
|
|
|
|
engine: newEngineMetrics(),
|
|
|
|
state: newStateMetrics(),
|
|
|
|
replicator: newReplicatorMetrics(),
|
|
|
|
treeService: newTreeServiceMetrics(),
|
|
|
|
epoch: metrics.NewGauge(prometheus.GaugeOpts{
|
|
|
|
Namespace: namespace,
|
|
|
|
Subsystem: innerRingSubsystem,
|
|
|
|
Name: "epoch",
|
|
|
|
Help: "Current epoch as seen by inner-ring node.",
|
|
|
|
}),
|
2023-06-09 12:14:32 +03:00
|
|
|
fstree: newFSTreeMetrics(),
|
|
|
|
blobstore: newBlobstoreMetrics(),
|
2023-08-18 11:14:10 +03:00
|
|
|
blobobvnizca: newBlobovnicza(),
|
2023-06-09 12:45:31 +03:00
|
|
|
metabase: newMetabaseMetrics(),
|
2023-06-09 16:19:47 +03:00
|
|
|
pilorama: newPiloramaMetrics(),
|
2023-08-09 09:23:03 +03:00
|
|
|
grpc: newGrpcServerMetrics(),
|
2023-10-04 19:20:59 +03:00
|
|
|
policer: newPolicerMetrics(),
|
2023-10-04 10:03:37 +03:00
|
|
|
morphClient: newMorphClientMetrics(),
|
|
|
|
morphCache: newMorphCacheMetrics(namespace),
|
2023-10-08 12:32:00 +03:00
|
|
|
log: logger.NewLogMetrics(namespace),
|
2021-03-16 11:14:56 +03:00
|
|
|
}
|
|
|
|
}
|
2021-12-28 13:39:42 +03:00
|
|
|
|
|
|
|
// SetEpoch updates epoch metric.
|
2022-07-19 18:16:42 +03:00
|
|
|
func (m *NodeMetrics) SetEpoch(epoch uint64) {
|
2023-05-31 12:25:32 +03:00
|
|
|
m.epoch.Set(float64(epoch))
|
2021-12-28 13:39:42 +03:00
|
|
|
}
|
2023-05-19 11:17:19 +03:00
|
|
|
|
2023-05-26 12:15:50 +03:00
|
|
|
func (m *NodeMetrics) TreeService() TreeMetricsRegister {
|
2023-05-24 10:01:50 +03:00
|
|
|
return m.treeService
|
|
|
|
}
|
2023-05-29 17:32:13 +03:00
|
|
|
|
2023-06-14 10:05:51 +03:00
|
|
|
func (m *NodeMetrics) Replicator() ReplicatorMetrics {
|
|
|
|
return m.replicator
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *NodeMetrics) ObjectService() ObjectServiceMetrics {
|
|
|
|
return m.objectService
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *NodeMetrics) Engine() EngineMetrics {
|
|
|
|
return m.engine
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *NodeMetrics) State() StateMetrics {
|
|
|
|
return m.state
|
2023-05-29 17:32:13 +03:00
|
|
|
}
|
2023-06-07 17:06:02 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) FSTree() FSTreeMetrics {
|
|
|
|
return m.fstree
|
|
|
|
}
|
2023-06-07 18:04:23 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) Blobstore() BlobstoreMetrics {
|
|
|
|
return m.blobstore
|
|
|
|
}
|
2023-06-09 12:14:32 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) BlobobvnizcaTreeMetrics() BlobobvnizcaMetrics {
|
|
|
|
return m.blobobvnizca
|
|
|
|
}
|
2023-06-09 12:45:31 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) MetabaseMetrics() MetabaseMetrics {
|
|
|
|
return m.metabase
|
|
|
|
}
|
2023-06-09 16:19:47 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) PiloramaMetrics() PiloramaMetrics {
|
|
|
|
return m.pilorama
|
|
|
|
}
|
2023-08-09 09:23:03 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) GrpcServerMetrics() GrpcServerMetrics {
|
|
|
|
return m.grpc
|
|
|
|
}
|
2023-10-04 19:20:59 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) PolicerMetrics() PolicerMetrics {
|
|
|
|
return m.policer
|
|
|
|
}
|
2023-10-04 10:03:37 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) MorphClientMetrics() morphmetrics.Register {
|
|
|
|
return m.morphClient
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *NodeMetrics) MorphCacheMetrics() MorphCacheMetrics {
|
|
|
|
return m.morphCache
|
|
|
|
}
|
2023-10-08 12:32:00 +03:00
|
|
|
|
|
|
|
func (m *NodeMetrics) LogMetrics() logger.LogMetrics {
|
|
|
|
return m.log
|
|
|
|
}
|