From 5fb2e87e2ee1e4e8123c701d1e2d8a0fd24cb21b Mon Sep 17 00:00:00 2001 From: Joshua Coutinho Date: Sun, 28 Apr 2019 16:56:44 +0000 Subject: [PATCH] wal: cleanup wal directory if creation fails delete /member/wal if any operation after the rename in wal.Create fails to avoid reading an inconsistent WAL on restart. Fixes #10688 --- wal/wal.go | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/wal/wal.go b/wal/wal.go index 0f8a25850a13..6c962ad2c737 100644 --- a/wal/wal.go +++ b/wal/wal.go @@ -195,6 +195,7 @@ func Create(lg *zap.Logger, dirpath string, metadata []byte) (*WAL, error) { zap.Error(perr), ) } + w.cleanupWAL(lg) return nil, perr } if perr = fileutil.Fsync(pdir); perr != nil { @@ -206,9 +207,10 @@ func Create(lg *zap.Logger, dirpath string, metadata []byte) (*WAL, error) { zap.Error(perr), ) } + w.cleanupWAL(lg) return nil, perr } - if perr = pdir.Close(); err != nil { + if perr = pdir.Close(); perr != nil { if lg != nil { lg.Warn( "failed to close the parent data directory file", @@ -217,12 +219,31 @@ func Create(lg *zap.Logger, dirpath string, metadata []byte) (*WAL, error) { zap.Error(perr), ) } + w.cleanupWAL(lg) return nil, perr } return w, nil } +func (w *WAL) cleanupWAL(lg *zap.Logger) { + var err error + if err = w.Close(); err != nil { + if lg != nil { + lg.Panic("failed to cleanup WAL", zap.Error(err)) + } else { + plog.Panicf("failed to cleanup WAL: %v", err) + } + } + if err = os.RemoveAll(w.dir); err != nil { + if lg != nil { + lg.Panic("failed to cleanup WAL", zap.Error(err)) + } else { + plog.Panicf("failed to cleanup WAL: %v", err) + } + } +} + func (w *WAL) renameWAL(tmpdirpath string) (*WAL, error) { if err := os.RemoveAll(w.dir); err != nil { return nil, err