From 94d73646cebc0242e64c886f21c884cb4a88ad12 Mon Sep 17 00:00:00 2001 From: Lazar Date: Mon, 18 Nov 2024 18:36:25 +0100 Subject: [PATCH 1/3] measure latency --- .../stakingeventwatcher/stakingeventwatcher.go | 15 +++++++++++++++ metrics/btcstaking_tracker.go | 6 ++++++ 2 files changed, 21 insertions(+) diff --git a/btcstaking-tracker/stakingeventwatcher/stakingeventwatcher.go b/btcstaking-tracker/stakingeventwatcher/stakingeventwatcher.go index b33fb81..2a873e1 100644 --- a/btcstaking-tracker/stakingeventwatcher/stakingeventwatcher.go +++ b/btcstaking-tracker/stakingeventwatcher/stakingeventwatcher.go @@ -175,6 +175,8 @@ func (sew *StakingEventWatcher) handleNewBlocks(blockNotifier *notifier.BlockEpo // checkBabylonDelegations iterates over all active babylon delegations, and reports not already // tracked delegations to the unbondingDelegationChan func (sew *StakingEventWatcher) checkBabylonDelegations(status btcstakingtypes.BTCDelegationStatus, addDel func(del Delegation)) error { + defer sew.latency(fmt.Sprintf("checkBabylonDelegations: %s", status))() + var i = uint64(0) for { delegations, err := sew.babylonNodeAdapter.DelegationsByStatus(status, i, sew.cfg.NewDelegationsBatchSize) @@ -610,6 +612,8 @@ func (sew *StakingEventWatcher) activateBtcDelegation( ctx, cancel := sew.quitContext() defer cancel() + defer sew.latency("activateBtcDelegation")() + if err := sew.pendingTracker.UpdateActivation(stakingTxHash, true); err != nil { sew.logger.Debugf("skipping tx %s is not in pending tracker, err: %v", stakingTxHash, err) } @@ -647,3 +651,14 @@ func (sew *StakingEventWatcher) activateBtcDelegation( }), ) } + +func (sew *StakingEventWatcher) latency(method string) func() { + startTime := time.Now() + return func() { + duration := time.Since(startTime) + sew.logger.Debug("execution time", + zap.String("method", method), + zap.Duration("latency", duration)) + sew.metrics.MethodExecutionLatency.WithLabelValues(method).Observe(duration.Seconds()) + } +} diff --git a/metrics/btcstaking_tracker.go b/metrics/btcstaking_tracker.go index 3a977d2..da1a79a 100644 --- a/metrics/btcstaking_tracker.go +++ b/metrics/btcstaking_tracker.go @@ -31,6 +31,7 @@ type UnbondingWatcherMetrics struct { DetectedNonUnbondingTransactionsCounter prometheus.Counter FailedReportedActivateDelegations prometheus.Counter ReportedActivateDelegationsCounter prometheus.Counter + MethodExecutionLatency *prometheus.HistogramVec } func newUnbondingWatcherMetrics(registry *prometheus.Registry) *UnbondingWatcherMetrics { @@ -66,6 +67,11 @@ func newUnbondingWatcherMetrics(registry *prometheus.Registry) *UnbondingWatcher Name: "unbonding_watcher_reported_activate_delegations", Help: "The total number of unbonding transactions successfully reported to Babylon node", }), + MethodExecutionLatency: registerer.NewHistogramVec(prometheus.HistogramOpts{ + Namespace: "unbonding_watcher_method_latency_seconds", + Help: "Latency in seconds", + Buckets: []float64{.001, .002, .005, .01, .025, .05, .1}, + }, []string{"method"}), } return uwMetrics From 394229c74700e35478540acbba96af73a43f8fb6 Mon Sep 17 00:00:00 2001 From: Lazar Date: Mon, 18 Nov 2024 18:40:12 +0100 Subject: [PATCH 2/3] changelog --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index bc12aa7..f16e334 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -37,6 +37,9 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) ## Unreleased +### Improvements +* [#105](https://github.com/babylonlabs-io/vigilante/pull/105) Measure latency + ## v0.16.0 * [#94](https://github.com/babylonlabs-io/vigilante/pull/94) adds gosec and fixes gosec issues From 80982109f070d6c54f2a43b72a03bfe9f98ff125 Mon Sep 17 00:00:00 2001 From: Lazar Date: Mon, 18 Nov 2024 18:51:15 +0100 Subject: [PATCH 3/3] change name prom --- metrics/btcstaking_tracker.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/metrics/btcstaking_tracker.go b/metrics/btcstaking_tracker.go index da1a79a..cf32a64 100644 --- a/metrics/btcstaking_tracker.go +++ b/metrics/btcstaking_tracker.go @@ -68,9 +68,9 @@ func newUnbondingWatcherMetrics(registry *prometheus.Registry) *UnbondingWatcher Help: "The total number of unbonding transactions successfully reported to Babylon node", }), MethodExecutionLatency: registerer.NewHistogramVec(prometheus.HistogramOpts{ - Namespace: "unbonding_watcher_method_latency_seconds", - Help: "Latency in seconds", - Buckets: []float64{.001, .002, .005, .01, .025, .05, .1}, + Name: "unbonding_watcher_method_latency_seconds", + Help: "Latency in seconds", + Buckets: []float64{.001, .002, .005, .01, .025, .05, .1}, }, []string{"method"}), }