mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-08 01:58:34 +08:00
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>
113 lines
3.6 KiB
Go
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)
|
|
}
|