Gracefully shutdown watched address fill service on interrupt
This commit is contained in:
parent
a141d154b7
commit
c8bdaefe97
@ -101,9 +101,11 @@ func serve() {
|
|||||||
logWithCommand.Info("state validator disabled")
|
logWithCommand.Info("state validator disabled")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var watchedAddressFillService *fill.Service
|
||||||
if serverConfig.WatchedAddressGapFillerEnabled {
|
if serverConfig.WatchedAddressGapFillerEnabled {
|
||||||
service := fill.New(serverConfig)
|
watchedAddressFillService = fill.New(serverConfig)
|
||||||
go service.Start()
|
wg.Add(1)
|
||||||
|
go watchedAddressFillService.Start(wg)
|
||||||
logWithCommand.Info("watched address gap filler enabled")
|
logWithCommand.Info("watched address gap filler enabled")
|
||||||
} else {
|
} else {
|
||||||
logWithCommand.Info("watched address gap filler disabled")
|
logWithCommand.Info("watched address gap filler disabled")
|
||||||
@ -115,6 +117,9 @@ func serve() {
|
|||||||
if graphQL != nil {
|
if graphQL != nil {
|
||||||
graphQL.Stop()
|
graphQL.Stop()
|
||||||
}
|
}
|
||||||
|
if watchedAddressFillService != nil {
|
||||||
|
watchedAddressFillService.Stop()
|
||||||
|
}
|
||||||
server.Stop()
|
server.Stop()
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@ package fill
|
|||||||
import (
|
import (
|
||||||
"math"
|
"math"
|
||||||
"strings"
|
"strings"
|
||||||
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
@ -46,6 +47,7 @@ type Service struct {
|
|||||||
db *sqlx.DB
|
db *sqlx.DB
|
||||||
client *rpc.Client
|
client *rpc.Client
|
||||||
interval int
|
interval int
|
||||||
|
quitChan chan bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewServer creates a new Service
|
// NewServer creates a new Service
|
||||||
@ -54,12 +56,32 @@ func New(config *serve.Config) *Service {
|
|||||||
db: config.DB,
|
db: config.DB,
|
||||||
client: config.Client,
|
client: config.Client,
|
||||||
interval: config.WatchedAddressGapFillInterval,
|
interval: config.WatchedAddressGapFillInterval,
|
||||||
|
quitChan: make(chan bool),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Start is used to begin the service
|
// Start is used to begin the service
|
||||||
func (s *Service) Start() {
|
func (s *Service) Start(wg *sync.WaitGroup) {
|
||||||
|
defer wg.Done()
|
||||||
for {
|
for {
|
||||||
|
select {
|
||||||
|
case <-s.quitChan:
|
||||||
|
log.Info("quiting eth ipld server process")
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
s.fill()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Stop is used to gracefully stop the service
|
||||||
|
func (s *Service) Stop() {
|
||||||
|
log.Info("stopping watched address gap filler")
|
||||||
|
close(s.quitChan)
|
||||||
|
}
|
||||||
|
|
||||||
|
// fill performs the filling of indexing gap for watched addresses
|
||||||
|
func (s *Service) fill() {
|
||||||
// Wait for specified interval duration
|
// Wait for specified interval duration
|
||||||
time.Sleep(time.Duration(s.interval) * time.Second)
|
time.Sleep(time.Duration(s.interval) * time.Second)
|
||||||
|
|
||||||
@ -98,7 +120,6 @@ func (s *Service) Start() {
|
|||||||
s.UpdateLastFilledAt(blockNumber, fillAddresses)
|
s.UpdateLastFilledAt(blockNumber, fillAddresses)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetFillAddresses finds the encompassing range to perform fill for the given watched addresses
|
// GetFillAddresses finds the encompassing range to perform fill for the given watched addresses
|
||||||
|
Loading…
Reference in New Issue
Block a user