-
-
Notifications
You must be signed in to change notification settings - Fork 362
/
Copy pathdelete_cleaner.go
48 lines (43 loc) · 1.01 KB
/
delete_cleaner.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
package commitlog
type Cleaner interface {
Clean([]*Segment) ([]*Segment, error)
}
// The delete cleaner implements the delete cleanup policy which
// deletes old log segments.
type DeleteCleaner struct {
Retention struct {
Bytes int64
}
}
func NewDeleteCleaner(bytes int64) *DeleteCleaner {
c := &DeleteCleaner{}
c.Retention.Bytes = bytes
return c
}
func (c *DeleteCleaner) Clean(segments []*Segment) ([]*Segment, error) {
if len(segments) == 0 || c.Retention.Bytes == -1 {
return segments, nil
}
cleanedSegments := []*Segment{segments[len(segments)-1]}
totalBytes := cleanedSegments[0].Position
if len(segments) > 1 {
var i int
for i = len(segments) - 2; i > -1; i-- {
s := segments[i]
totalBytes += s.Position
if totalBytes > c.Retention.Bytes {
break
}
cleanedSegments = append([]*Segment{s}, cleanedSegments...)
}
if i > -1 {
for ; i != 0; i-- {
s := segments[i]
if err := s.Delete(); err != nil {
return nil, err
}
}
}
}
return cleanedSegments, nil
}