Skip to content

Commit

Permalink
Merge pull request #1927 from sawsa307/neg-syncer-staleness-metrics
Browse files Browse the repository at this point in the history
Add metrics to track syncer staleness
  • Loading branch information
k8s-ci-robot authored Feb 15, 2023
2 parents 394ae02 + d0c5951 commit 009e314
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 0 deletions.
17 changes: 17 additions & 0 deletions pkg/neg/metrics/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ const (
negOpLatencyKey = "neg_operation_duration_seconds"
negOpEndpointsKey = "neg_operation_endpoints"
lastSyncTimestampKey = "sync_timestamp"
syncerStalenessKey = "syncer_staleness"

resultSuccess = "success"
resultError = "error"
Expand Down Expand Up @@ -127,6 +128,17 @@ var (
Help: "The timestamp of the last execution of NEG controller sync loop.",
},
)

// SyncerStaleness tracks for every syncer, how long since the syncer last syncs
SyncerStaleness = prometheus.NewHistogram(
prometheus.HistogramOpts{
Subsystem: negControllerSubsystem,
Name: syncerStalenessKey,
Help: "The duration of a syncer since it last syncs",
// custom buckets - [1s, 2s, 4s, 8s, 16s, 32s, 64s, 128s, 256s(~4min), 512s(~8min), 1024s(~17min), 2048 (~34min), 4096(~68min), 8192(~136min), +Inf]
Buckets: prometheus.ExponentialBuckets(1, 2, 14),
},
)
)

var register sync.Once
Expand All @@ -139,6 +151,7 @@ func RegisterMetrics() {
prometheus.MustRegister(SyncerSyncLatency)
prometheus.MustRegister(LastSyncTimestamp)
prometheus.MustRegister(InitializationLatency)
prometheus.MustRegister(SyncerStaleness)

RegisterSyncerMetrics()
})
Expand Down Expand Up @@ -170,6 +183,10 @@ func PublishNegInitializationMetrics(latency time.Duration) {
InitializationLatency.Observe(latency.Seconds())
}

func PublishNegSyncerStalenessMetrics(syncerStaleness time.Duration) {
SyncerStaleness.Observe(syncerStaleness.Seconds())
}

func getResult(err error) string {
if err != nil {
return resultError
Expand Down
1 change: 1 addition & 0 deletions pkg/neg/syncers/transaction.go
Original file line number Diff line number Diff line change
Expand Up @@ -710,6 +710,7 @@ func (s *transactionSyncer) updateStatus(syncErr error) {
if _, _, exists := findCondition(neg.Status.Conditions, negv1beta1.Initialized); !exists {
s.needInit = true
}
metrics.PublishNegSyncerStalenessMetrics(ts.Sub(neg.Status.LastSyncTime.Time))

ensureCondition(neg, getSyncedCondition(syncErr))
neg.Status.LastSyncTime = ts
Expand Down

0 comments on commit 009e314

Please sign in to comment.