From f530eeeb41b72df3e8f8c88975e19c064db16d32 Mon Sep 17 00:00:00 2001 From: maskpp Date: Mon, 1 Jul 2024 10:38:32 +0800 Subject: [PATCH] close db connection --- packages/relayer/event.go | 1 + packages/relayer/indexer/indexer.go | 5 +++++ packages/relayer/pkg/http/server.go | 6 ++++++ packages/relayer/pkg/mock/event_repository.go | 5 +++++ packages/relayer/pkg/repo/event.go | 10 ++++++++++ packages/relayer/processor/processor.go | 5 +++++ packages/relayer/watchdog/watchdog.go | 5 +++++ 7 files changed, 37 insertions(+) diff --git a/packages/relayer/event.go b/packages/relayer/event.go index f2e8c9badcd..cc2afc3558f 100644 --- a/packages/relayer/event.go +++ b/packages/relayer/event.go @@ -128,6 +128,7 @@ type FindAllByAddressOpts struct { // EventRepository is used to interact with events in the store type EventRepository interface { + Close() error Save(ctx context.Context, opts *SaveEventOpts) (*Event, error) UpdateStatus(ctx context.Context, id int, status EventStatus) error UpdateFeesAndProfitability(ctx context.Context, id int, opts *UpdateFeesAndProfitabilityOpts) error diff --git a/packages/relayer/indexer/indexer.go b/packages/relayer/indexer/indexer.go index 62bc8328c7f..d6bee28b2d3 100644 --- a/packages/relayer/indexer/indexer.go +++ b/packages/relayer/indexer/indexer.go @@ -259,6 +259,11 @@ func (i *Indexer) Name() string { // context is stopped externally by cmd/main.go shutdown. func (i *Indexer) Close(ctx context.Context) { i.wg.Wait() + + // Close db connection. + if err := i.eventRepo.Close(); err != nil { + slog.Error("Failed to close db connection", "err", err) + } } // Start starts the indexer, which should initialize the queue, add to wait groups, diff --git a/packages/relayer/pkg/http/server.go b/packages/relayer/pkg/http/server.go index 9439e711f92..c3739197f9f 100644 --- a/packages/relayer/pkg/http/server.go +++ b/packages/relayer/pkg/http/server.go @@ -2,6 +2,7 @@ package http import ( "context" + "log/slog" "math/big" "net/http" "os" @@ -130,6 +131,11 @@ func (srv *Server) Start(address string) error { // Shutdown shuts down the HTTP server func (srv *Server) Shutdown(ctx context.Context) error { + // Close db connection. + if err := srv.eventRepo.Close(); err != nil { + slog.Error("Failed to close db connection", "err", err) + } + return srv.echo.Shutdown(ctx) } diff --git a/packages/relayer/pkg/mock/event_repository.go b/packages/relayer/pkg/mock/event_repository.go index 29665c393b5..0456ba7c2c6 100644 --- a/packages/relayer/pkg/mock/event_repository.go +++ b/packages/relayer/pkg/mock/event_repository.go @@ -22,6 +22,11 @@ func NewEventRepository() *EventRepository { events: make([]*relayer.Event, 0), } } + +func (r *EventRepository) Close() error { + return nil +} + func (r *EventRepository) Save(ctx context.Context, opts *relayer.SaveEventOpts) (*relayer.Event, error) { r.events = append(r.events, &relayer.Event{ ID: rand.Int(), // nolint: gosec diff --git a/packages/relayer/pkg/repo/event.go b/packages/relayer/pkg/repo/event.go index 80d9e149d09..3309c9982f8 100644 --- a/packages/relayer/pkg/repo/event.go +++ b/packages/relayer/pkg/repo/event.go @@ -30,6 +30,16 @@ func NewEventRepository(dbHandler db.DB) (*EventRepository, error) { }, nil } +// Close closes the database connection. +func (r *EventRepository) Close() error { + sqlDB, err := r.db.DB() + if err != nil { + return err + } + + return sqlDB.Close() +} + func (r *EventRepository) Save(ctx context.Context, opts *relayer.SaveEventOpts) (*relayer.Event, error) { e := &relayer.Event{ Data: datatypes.JSON(opts.Data), diff --git a/packages/relayer/processor/processor.go b/packages/relayer/processor/processor.go index da9b0bc3f7c..79145ef030d 100644 --- a/packages/relayer/processor/processor.go +++ b/packages/relayer/processor/processor.go @@ -390,6 +390,11 @@ func (p *Processor) Close(ctx context.Context) { p.cancel() p.wg.Wait() + + // Close db connection. + if err := p.eventRepo.Close(); err != nil { + slog.Error("Failed to close db connection", "err", err) + } } func (p *Processor) Start() error { diff --git a/packages/relayer/watchdog/watchdog.go b/packages/relayer/watchdog/watchdog.go index 7a8c7826dbb..a860cbd0324 100644 --- a/packages/relayer/watchdog/watchdog.go +++ b/packages/relayer/watchdog/watchdog.go @@ -210,6 +210,11 @@ func (w *Watchdog) Close(ctx context.Context) { w.cancel() w.wg.Wait() + + // Close db connection. + if err := w.eventRepo.Close(); err != nil { + slog.Error("Failed to close db connection", "err", err) + } } func (w *Watchdog) Start() error {