mirror of
https://github.com/minio/minio.git
synced 2025-11-09 21:49:46 -05:00
Add notification queue metrics (#16026)
This commit is contained in:
@@ -19,6 +19,7 @@ package event
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"strings"
|
||||
"sync"
|
||||
"sync/atomic"
|
||||
)
|
||||
@@ -35,6 +36,26 @@ type Target interface {
|
||||
Save(Event) error
|
||||
Send(string) error
|
||||
Close() error
|
||||
Store() TargetStore
|
||||
}
|
||||
|
||||
// TargetStore is a shallow version of a target.Store
|
||||
type TargetStore interface {
|
||||
Len() int
|
||||
}
|
||||
|
||||
// TargetStats is a collection of stats for multiple targets.
|
||||
type TargetStats struct {
|
||||
// CurrentSendCalls is the number of concurrent async Send calls to all targets
|
||||
CurrentSendCalls int64
|
||||
|
||||
TargetStats map[string]TargetStat
|
||||
}
|
||||
|
||||
// TargetStat is the stats of a single target.
|
||||
type TargetStat struct {
|
||||
ID TargetID
|
||||
CurrentQueue int // Populated if target has a store.
|
||||
}
|
||||
|
||||
// TargetList - holds list of targets indexed by target ID.
|
||||
@@ -166,6 +187,26 @@ func (list *TargetList) Send(event Event, targetIDset TargetIDSet, resCh chan<-
|
||||
}()
|
||||
}
|
||||
|
||||
// Stats returns stats for targets.
|
||||
func (list *TargetList) Stats() TargetStats {
|
||||
t := TargetStats{}
|
||||
if list == nil {
|
||||
return t
|
||||
}
|
||||
t.CurrentSendCalls = atomic.LoadInt64(&list.currentSendCalls)
|
||||
list.RLock()
|
||||
defer list.RUnlock()
|
||||
t.TargetStats = make(map[string]TargetStat, len(list.targets))
|
||||
for id, target := range list.targets {
|
||||
ts := TargetStat{ID: id}
|
||||
if st := target.Store(); st != nil {
|
||||
ts.CurrentQueue = st.Len()
|
||||
}
|
||||
t.TargetStats[strings.ReplaceAll(id.String(), ":", "_")] = ts
|
||||
}
|
||||
return t
|
||||
}
|
||||
|
||||
// NewTargetList - creates TargetList.
|
||||
func NewTargetList() *TargetList {
|
||||
return &TargetList{targets: make(map[TargetID]Target)}
|
||||
|
||||
Reference in New Issue
Block a user