Skip to content

Commit

Permalink
pruning
Browse files Browse the repository at this point in the history
  • Loading branch information
NazariiDenha committed Oct 7, 2024
1 parent 854dc43 commit 294b9c6
Showing 1 changed file with 45 additions and 1 deletion.
46 changes: 45 additions & 1 deletion rollup/l1/tracker.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,8 @@ func (t *Tracker) Start() {
go func() {
syncTicker := time.NewTicker(defaultSyncInterval)
defer syncTicker.Stop()

pruneTicker := time.NewTicker(defaultPruneInterval)
defer pruneTicker.Stop()
for {
select {
case <-t.ctx.Done():
Expand All @@ -76,6 +77,8 @@ func (t *Tracker) Start() {
if err != nil {
log.Warn("Tracker: failed to sync latest head", "err", err)
}
case <-pruneTicker.C:
t.pruneOldHeaders()
}

}
Expand Down Expand Up @@ -459,6 +462,47 @@ func (t *Tracker) Subscribe(confirmationRule ConfirmationRule, callback Subscrip
}
}

func (t *Tracker) pruneOldHeaders() {
// can prune all headers that are older than last sent header - 2 epochs (reorg deeper than that can't happen)
t.mu.Lock()
defer t.mu.Unlock()
var minNumber *big.Int
for _, confRule := range []ConfirmationRule{LatestChainHead, SafeChainHead, FinalizedChainHead} {
for _, sub := range t.subscriptions[confRule] {
if sub.lastSentHeader == nil { // did not sent anything to this subscriber, so it's impossible to determine no, which headers could be pruned
return
}
if minNumber == nil {
minNumber = big.NewInt(0).Set(sub.lastSentHeader.Number)
continue
}
if sub.lastSentHeader.Number.Cmp(minNumber) < 0 {
minNumber.Set(sub.lastSentHeader.Number)
}
}
}
if minNumber == nil {
return
}
minNumber.Sub(minNumber, big.NewInt(int64(maxConfirmationRule)))

// prune from canonical chain
keys := t.canonicalChain.Keys()
for _, key := range keys {
if key <= minNumber.Uint64() {
t.canonicalChain.Delete(key)
}
}

// prune from all headers
headers := t.headers.Values()
for _, header := range headers {
if header.Number.Cmp(minNumber) <= 0 {
t.headers.Delete(header.Hash())
}
}
}

func (t *Tracker) Stop() {
log.Info("stopping Tracker")
t.cancel()
Expand Down

0 comments on commit 294b9c6

Please sign in to comment.