From 8a6a42947fb14cf576a97b2a4a80e750ff48d30d Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Wed, 1 Mar 2023 13:45:16 -0800 Subject: [PATCH 1/3] relayer events for prometheus metrics --- go.mod | 6 ++--- go.sum | 6 +++++ .../relayer/indexer/filter_then_subscribe.go | 1 + packages/relayer/message/process_message.go | 8 ++++++ packages/relayer/prometheus.go | 25 +++++++++++++++++++ 5 files changed, 43 insertions(+), 3 deletions(-) create mode 100644 packages/relayer/prometheus.go diff --git a/go.mod b/go.mod index db6e595c604..925f38a1ef1 100644 --- a/go.mod +++ b/go.mod @@ -73,8 +73,8 @@ require ( github.com/opencontainers/image-spec v1.0.3-0.20211202183452-c5a74bcca799 // indirect github.com/opencontainers/runc v1.1.3 // indirect github.com/pmezard/go-difflib v1.0.0 // indirect - github.com/prometheus/client_golang v1.12.2 // indirect - github.com/prometheus/client_model v0.2.0 // indirect + github.com/prometheus/client_golang v1.14.0 // indirect + github.com/prometheus/client_model v0.3.0 // indirect github.com/prometheus/common v0.37.0 // indirect github.com/prometheus/procfs v0.8.0 // indirect github.com/rjeczalik/notify v0.9.1 // indirect @@ -92,7 +92,7 @@ require ( golang.org/x/time v0.0.0-20220722155302-e5dcc9cfc0b9 // indirect google.golang.org/genproto v0.0.0-20220617124728-180714bec0ad // indirect google.golang.org/grpc v1.48.0 // indirect - google.golang.org/protobuf v1.28.0 // indirect + google.golang.org/protobuf v1.28.1 // indirect gopkg.in/natefinch/npipe.v2 v2.0.0-20160621034901-c1b8fa8bdcce // indirect gopkg.in/yaml.v3 v3.0.1 // indirect ) diff --git a/go.sum b/go.sum index 5c9e193dcc1..b33ba94eca9 100644 --- a/go.sum +++ b/go.sum @@ -777,12 +777,16 @@ github.com/prometheus/client_golang v1.11.0/go.mod h1:Z6t4BnS23TR94PD6BsDNk8yVqr github.com/prometheus/client_golang v1.12.1/go.mod h1:3Z9XVyYiZYEO+YQWt3RD2R3jrbd179Rt297l4aS6nDY= github.com/prometheus/client_golang v1.12.2 h1:51L9cDoUHVrXx4zWYlcLQIZ+d+VXHgqnYKkIuq4g/34= github.com/prometheus/client_golang v1.12.2/go.mod h1:3Z9XVyYiZYEO+YQWt3RD2R3jrbd179Rt297l4aS6nDY= +github.com/prometheus/client_golang v1.14.0 h1:nJdhIvne2eSX/XRAFV9PcvFFRbrjbcTUj0VP62TMhnw= +github.com/prometheus/client_golang v1.14.0/go.mod h1:8vpkKitgIVNcqrRBWh1C4TIUQgYNtG/XQE4E/Zae36Y= github.com/prometheus/client_model v0.0.0-20171117100541-99fa1f4be8e5/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo= github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo= github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/client_model v0.2.0 h1:uq5h0d+GuxiXLJLNABMgp2qUWDPiLvgCzz2dUR+/W/M= github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= +github.com/prometheus/client_model v0.3.0 h1:UBgGFHqYdG/TPFD1B1ogZywDqEkwp3fBMvqdiQ7Xew4= +github.com/prometheus/client_model v0.3.0/go.mod h1:LDGWKZIo7rky3hgvBe+caln+Dr3dPggB5dvjtD7w9+w= github.com/prometheus/common v0.0.0-20180110214958-89604d197083/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro= github.com/prometheus/common v0.0.0-20181113130724-41aa239b4cce/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro= github.com/prometheus/common v0.4.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= @@ -1366,6 +1370,8 @@ google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQ google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= google.golang.org/protobuf v1.28.0 h1:w43yiav+6bVFTBQFZX0r7ipe9JQ1QsbMgHwbBziscLw= google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.28.1 h1:d0NfwRgPtno5B1Wa6L2DAG+KivqkdutMf1UhdNx175w= +google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= gopkg.in/airbrake/gobrake.v2 v2.0.9/go.mod h1:/h5ZAUhDkGaJfjzjKLSjv6zCL6O0LLBxU4K+aSYdM/U= gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= diff --git a/packages/relayer/indexer/filter_then_subscribe.go b/packages/relayer/indexer/filter_then_subscribe.go index 9fb5dbc05f4..0d949fb087b 100644 --- a/packages/relayer/indexer/filter_then_subscribe.go +++ b/packages/relayer/indexer/filter_then_subscribe.go @@ -88,6 +88,7 @@ func (svc *Service) FilterThenSubscribe( group.Go(func() error { err := svc.handleEvent(groupCtx, chainID, event) if err != nil { + relayer.ErrorEvents.Inc() // log error but always return nil to keep other goroutines active log.Error(err.Error()) } diff --git a/packages/relayer/message/process_message.go b/packages/relayer/message/process_message.go index 4d53f2bd144..c32f2b7be29 100644 --- a/packages/relayer/message/process_message.go +++ b/packages/relayer/message/process_message.go @@ -84,6 +84,8 @@ func (p *Processor) ProcessMessage( return errors.Wrap(err, "p.sendProcessMessageCall") } + relayer.EventsProcessed.Inc() + log.Infof("waiting for tx hash %v", hex.EncodeToString(tx.Hash().Bytes())) _, err = relayer.WaitReceipt(ctx, p.destEthClient, tx.Hash()) @@ -100,6 +102,12 @@ func (p *Processor) ProcessMessage( log.Infof("updating message status to: %v", relayer.EventStatus(messageStatus).String()) + if messageStatus == uint8(relayer.EventStatusRetriable) { + relayer.RetriableEvents.Inc() + } else if messageStatus == uint8(relayer.EventStatusDone) { + relayer.DoneEvents.Inc() + } + // update message status if err := p.eventRepo.UpdateStatus(ctx, e.ID, relayer.EventStatus(messageStatus)); err != nil { return errors.Wrap(err, "s.eventRepo.UpdateStatus") diff --git a/packages/relayer/prometheus.go b/packages/relayer/prometheus.go new file mode 100644 index 00000000000..091521243e0 --- /dev/null +++ b/packages/relayer/prometheus.go @@ -0,0 +1,25 @@ +package relayer + +import ( + "github.com/prometheus/client_golang/prometheus" + "github.com/prometheus/client_golang/prometheus/promauto" +) + +var ( + EventsProcessed = promauto.NewCounter(prometheus.CounterOpts{ + Name: "events_processed_ops_total", + Help: "The total number of processed events", + }) + RetriableEvents = promauto.NewCounter(prometheus.CounterOpts{ + Name: "events_processed_retriable_status_ops_total", + Help: "The total number of processed events that ended up in Retriable status", + }) + DoneEvents = promauto.NewCounter(prometheus.CounterOpts{ + Name: "events_processed_done_status_ops_total", + Help: "The total number of processed events that ended up in Done status", + }) + ErrorEvents = promauto.NewCounter(prometheus.CounterOpts{ + Name: "events_processed_done_error_ops_total", + Help: "The total number of processed events that failed due to an error", + }) +) From 92a5303ece1decfe5e556f5a20a2528768a76c62 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Wed, 1 Mar 2023 13:51:33 -0800 Subject: [PATCH 2/3] blocks processed inc --- packages/relayer/indexer/handle_no_events_in_batch.go | 2 ++ packages/relayer/indexer/subscribe.go | 2 ++ packages/relayer/prometheus.go | 4 ++++ 3 files changed, 8 insertions(+) diff --git a/packages/relayer/indexer/handle_no_events_in_batch.go b/packages/relayer/indexer/handle_no_events_in_batch.go index 6ee402922b0..bac69757830 100644 --- a/packages/relayer/indexer/handle_no_events_in_batch.go +++ b/packages/relayer/indexer/handle_no_events_in_batch.go @@ -32,6 +32,8 @@ func (svc *Service) handleNoEventsInBatch( return errors.Wrap(err, "svc.blockRepo.Save") } + relayer.BlocksProcessed.Inc() + svc.processingBlockHeight = uint64(blockNumber) return nil diff --git a/packages/relayer/indexer/subscribe.go b/packages/relayer/indexer/subscribe.go index 02ea554e6fc..50cab3ad180 100644 --- a/packages/relayer/indexer/subscribe.go +++ b/packages/relayer/indexer/subscribe.go @@ -56,6 +56,8 @@ func (svc *Service) subscribe(ctx context.Context, chainID *big.Int) error { if err != nil { log.Errorf("svc.subscribe, svc.blockRepo.Save: %v", err) } + + relayer.BlocksProcessed.Inc() } }() } diff --git a/packages/relayer/prometheus.go b/packages/relayer/prometheus.go index 091521243e0..8bf590ec5e4 100644 --- a/packages/relayer/prometheus.go +++ b/packages/relayer/prometheus.go @@ -10,6 +10,10 @@ var ( Name: "events_processed_ops_total", Help: "The total number of processed events", }) + BlocksProcessed = promauto.NewCounter(prometheus.CounterOpts{ + Name: "blocks_processed_ops_total", + Help: "The total number of processed blocks", + }) RetriableEvents = promauto.NewCounter(prometheus.CounterOpts{ Name: "events_processed_retriable_status_ops_total", Help: "The total number of processed events that ended up in Retriable status", From d86c315f8d9524ebbc661a9ef77b0336442bf646 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Wed, 1 Mar 2023 13:52:54 -0800 Subject: [PATCH 3/3] rename --- packages/relayer/prometheus.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/relayer/prometheus.go b/packages/relayer/prometheus.go index 8bf590ec5e4..8d3dfefb11f 100644 --- a/packages/relayer/prometheus.go +++ b/packages/relayer/prometheus.go @@ -23,7 +23,7 @@ var ( Help: "The total number of processed events that ended up in Done status", }) ErrorEvents = promauto.NewCounter(prometheus.CounterOpts{ - Name: "events_processed_done_error_ops_total", + Name: "events_processed_error_ops_total", Help: "The total number of processed events that failed due to an error", }) )