-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Copy pathgc.go
96 lines (75 loc) · 2.28 KB
/
gc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
package index
import (
"context"
"strconv"
"time"
logging "github.com/ipfs/go-log/v2"
"github.com/filecoin-project/lotus/chain/actors/builtin"
)
var (
log = logging.Logger("chainindex")
cleanupInterval = time.Duration(4) * time.Hour
)
func (si *SqliteIndexer) gcLoop() {
defer si.wg.Done()
// Initial cleanup before entering the loop
si.gc(si.ctx)
cleanupTicker := time.NewTicker(cleanupInterval)
defer cleanupTicker.Stop()
for si.ctx.Err() == nil {
if si.isClosed() {
return
}
select {
case <-cleanupTicker.C:
si.gc(si.ctx)
case <-si.ctx.Done():
return
}
}
}
func (si *SqliteIndexer) gc(ctx context.Context) {
if si.gcRetentionEpochs <= 0 {
log.Info("gc retention epochs is not set, skipping gc")
return
}
log.Info("starting index gc")
head := si.cs.GetHeaviestTipSet()
removalEpoch := int64(head.Height()) - si.gcRetentionEpochs - 10 // 10 is for some grace period
if removalEpoch <= 0 {
log.Info("no tipsets to gc")
return
}
log.Infof("gc'ing all (reverted and non-reverted) tipsets before epoch %d", removalEpoch)
res, err := si.stmts.removeTipsetsBeforeHeightStmt.ExecContext(ctx, removalEpoch)
if err != nil {
log.Errorw("failed to remove reverted tipsets before height", "height", removalEpoch, "error", err)
return
}
rows, err := res.RowsAffected()
if err != nil {
log.Errorw("failed to get rows affected", "error", err)
return
}
log.Infof("gc'd %d entries before epoch %d", rows, removalEpoch)
// -------------------------------------------------------------------------------------------------
// Also GC eth hashes
// Convert gcRetentionEpochs to number of days
gcRetentionDays := si.gcRetentionEpochs / (builtin.EpochsInDay)
if gcRetentionDays < 1 {
log.Infof("skipping gc of eth hashes as retention days is less than 1")
return
}
log.Infof("gc'ing eth hashes older than %d days", gcRetentionDays)
res, err = si.stmts.removeEthHashesOlderThanStmt.ExecContext(ctx, "-"+strconv.Itoa(int(gcRetentionDays))+" day")
if err != nil {
log.Errorf("failed to gc eth hashes older than %d days: %w", gcRetentionDays, err)
return
}
rows, err = res.RowsAffected()
if err != nil {
log.Errorf("failed to get rows affected: %w", err)
return
}
log.Infof("gc'd %d eth hashes older than %d days", rows, gcRetentionDays)
}