Zhen Ye c9b0748ff9
enhance: add delete rows into delete msg header and more metric (#41952)
issue: #41544

- add delete rows into delete messsage header
- add more insert/delete metrics
- fix non-broadcast message has broadcast header

Signed-off-by: chyezh <chyezh@outlook.com>
2025-05-22 20:28:26 +08:00

113 lines
3.6 KiB
Go

package metricsutil
import (
"github.com/prometheus/client_golang/prometheus"
"github.com/milvus-io/milvus/pkg/v2/metrics"
"github.com/milvus-io/milvus/pkg/v2/util/paramtable"
)
type GrowingSegmentState string
func NewSegmentAssignMetrics(pchannel string) *SegmentAssignMetrics {
constLabel := prometheus.Labels{
metrics.NodeIDLabelName: paramtable.GetStringNodeID(),
metrics.WALChannelLabelName: pchannel,
}
return &SegmentAssignMetrics{
constLabel: constLabel,
allocTotal: metrics.WALSegmentAllocTotal.With(constLabel),
segmentRowsTotal: metrics.WALSegmentRowsTotal.With(constLabel),
segmentBytes: metrics.WALSegmentBytes.With(constLabel),
flushedTotal: metrics.WALSegmentFlushedTotal.MustCurryWith(constLabel),
partitionTotal: metrics.WALPartitionTotal.With(constLabel),
collectionTotal: metrics.WALCollectionTotal.With(constLabel),
insertRowsTotal: metrics.WALInsertRowsTotal.With(constLabel),
insertBytes: metrics.WALInsertBytes.With(constLabel),
deleteRowsTotal: metrics.WALDeleteRowsTotal.With(constLabel),
}
}
// SegmentAssignMetrics is the metrics of the segment assignment.
type SegmentAssignMetrics struct {
constLabel prometheus.Labels
onAllocTotal prometheus.Gauge
onFlushTotal prometheus.Gauge
allocTotal prometheus.Gauge
segmentRowsTotal prometheus.Observer
segmentBytes prometheus.Observer
flushedTotal *prometheus.CounterVec
partitionTotal prometheus.Gauge
collectionTotal prometheus.Gauge
insertRowsTotal prometheus.Counter
insertBytes prometheus.Counter
deleteRowsTotal prometheus.Counter
}
// ObserveOnAllocating observe a allocating operation and return a guard function.
func (m *SegmentAssignMetrics) ObserveOnAllocating() func() {
m.onAllocTotal.Inc()
return func() {
m.onAllocTotal.Dec()
}
}
// ObserveOnFlushing observe a flush operation and return a guard function.
func (m *SegmentAssignMetrics) ObseveOnFlushing() func() {
m.onFlushTotal.Inc()
return func() {
m.onFlushTotal.Dec()
}
}
// ObserveInsert observe a insert operation
func (m *SegmentAssignMetrics) ObserveInsert(rows uint64, bytes uint64) {
m.insertRowsTotal.Add(float64(rows))
m.insertBytes.Add(float64(bytes))
}
// ObserveDelete observe a insert operation
func (m *SegmentAssignMetrics) ObserveDelete(rows uint64) {
m.deleteRowsTotal.Add(float64(rows))
}
// ObserveCreateSegment increments the total number of growing segment.
func (m *SegmentAssignMetrics) ObserveCreateSegment() {
m.allocTotal.Inc()
}
// ObserveSegmentFlushed records the number of bytes flushed and increments the total number of flushed segments.
func (m *SegmentAssignMetrics) ObserveSegmentFlushed(policy string, rows int64, bytes int64) {
m.allocTotal.Dec()
m.flushedTotal.WithLabelValues(policy).Inc()
m.segmentRowsTotal.Observe(float64(rows))
m.segmentBytes.Observe(float64(bytes))
}
func (m *SegmentAssignMetrics) UpdateSegmentCount(cnt int) {
m.allocTotal.Set(float64(cnt))
}
func (m *SegmentAssignMetrics) UpdatePartitionCount(cnt int) {
m.partitionTotal.Set(float64(cnt))
}
func (m *SegmentAssignMetrics) UpdateCollectionCount(cnt int) {
m.collectionTotal.Set(float64(cnt))
}
func (m *SegmentAssignMetrics) Close() {
metrics.WALSegmentAllocTotal.Delete(m.constLabel)
metrics.WALSegmentFlushedTotal.DeletePartialMatch(m.constLabel)
metrics.WALSegmentRowsTotal.Delete(m.constLabel)
metrics.WALSegmentBytes.Delete(m.constLabel)
metrics.WALPartitionTotal.Delete(m.constLabel)
metrics.WALCollectionTotal.Delete(m.constLabel)
metrics.WALInsertRowsTotal.Delete(m.constLabel)
metrics.WALDeleteRowsTotal.Delete(m.constLabel)
metrics.WALInsertBytes.Delete(m.constLabel)
}