From 27f033a509703e4440cf729f008dda17bbf81dfc Mon Sep 17 00:00:00 2001 From: Chris Hager Date: Fri, 19 Apr 2024 17:30:09 +0200 Subject: [PATCH] fix batch save --- cmd/core/data-api-backfill.go | 1 + database/database.go | 18 ++++++++++++++++-- 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/cmd/core/data-api-backfill.go b/cmd/core/data-api-backfill.go index ac065ea..dd17cb5 100644 --- a/cmd/core/data-api-backfill.go +++ b/cmd/core/data-api-backfill.go @@ -53,6 +53,7 @@ var backfillDataAPICmd = &cobra.Command{ } } + log.Infof("Relayscan %s", vars.Version) log.Infof("Using %d relays", len(relays)) for index, relay := range relays { log.Infof("relay #%d: %s", index+1, relay.Hostname()) diff --git a/database/database.go b/database/database.go index f9dbd2c..370c8e9 100644 --- a/database/database.go +++ b/database/database.go @@ -72,12 +72,25 @@ func (s *DatabaseService) SaveDataAPIPayloadDeliveredBatch(entries []*DataAPIPay if len(entries) == 0 { return nil } + query := `INSERT INTO ` + TableDataAPIPayloadDelivered + ` (relay, epoch, slot, parent_hash, block_hash, builder_pubkey, proposer_pubkey, proposer_fee_recipient, gas_limit, gas_used, value_claimed_wei, value_claimed_eth, num_tx, block_number, extra_data) VALUES (:relay, :epoch, :slot, :parent_hash, :block_hash, :builder_pubkey, :proposer_pubkey, :proposer_fee_recipient, :gas_limit, :gas_used, :value_claimed_wei, :value_claimed_eth, :num_tx, :block_number, :extra_data) ON CONFLICT DO NOTHING` - _, err := s.DB.NamedExec(query, entries) - return err + + // Postgres can do max 65535 parameters at a time (otherwise error: "pq: got ... parameters but PostgreSQL only supports 65535 parameters") + for i := 0; i < len(entries); i += 3000 { + end := i + 3000 + if end > len(entries) { + end = len(entries) + } + + _, err := s.DB.NamedExec(query, entries[i:end]) + if err != nil { + return err + } + } + return nil } func (s *DatabaseService) GetDataAPILatestPayloadDelivered(relay string) (*DataAPIPayloadDeliveredEntry, error) { @@ -116,6 +129,7 @@ func (s *DatabaseService) GetDataAPILatestBid(relay string) (*DataAPIBuilderBidE } func (s *DatabaseService) GetTopRelays(since, until time.Time) (res []*TopRelayEntry, err error) { + // slot_start =slotToTime query := `SELECT relay, count(relay) as payloads FROM ` + TableDataAPIPayloadDelivered + ` WHERE inserted_at > $1 AND inserted_at < $2 GROUP BY relay ORDER BY payloads DESC;` err = s.DB.Select(&res, query, since.UTC(), until.UTC()) return res, err