mirror of
https://github.com/prometheus/prometheus.git
synced 2024-11-10 07:34:04 -08:00
Close consumed WAL segments, verify checksums on read
This commit is contained in:
parent
eeb03e97e2
commit
84e8027a8e
22
wal.go
22
wal.go
|
@ -97,7 +97,7 @@ type walHandler struct {
|
|||
|
||||
// ReadAll consumes all entries in the WAL and triggers the registered handlers.
|
||||
func (w *WAL) ReadAll(h *walHandler) error {
|
||||
for _, f := range w.files {
|
||||
for i, f := range w.files {
|
||||
dec := newWALDecoder(f, h)
|
||||
|
||||
for {
|
||||
|
@ -109,6 +109,13 @@ func (w *WAL) ReadAll(h *walHandler) error {
|
|||
return err
|
||||
}
|
||||
}
|
||||
|
||||
// Close completed file after we are done reading it.
|
||||
if i < len(w.files)-1 {
|
||||
if err := f.Close(); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
@ -524,14 +531,19 @@ func (d *walDecoder) entry() error {
|
|||
}
|
||||
buf := d.buf[:length]
|
||||
|
||||
if _, err := d.r.Read(buf); err != nil {
|
||||
cw := crc32.NewIEEE()
|
||||
tr := io.TeeReader(d.r, cw)
|
||||
|
||||
if _, err := tr.Read(buf); err != nil {
|
||||
return err
|
||||
}
|
||||
// Read away checksum.
|
||||
// TODO(fabxc): verify it
|
||||
if _, err := d.r.Read(b[:4]); err != nil {
|
||||
_, err := d.r.Read(b[:4])
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if exp, has := binary.BigEndian.Uint32(b[:4]), cw.Sum32(); has != exp {
|
||||
return errors.Errorf("unexpected CRC32 checksum %x, want %x", has, exp)
|
||||
}
|
||||
|
||||
switch etype {
|
||||
case WALEntrySeries:
|
||||
|
|
Loading…
Reference in a new issue