leveldb recover error handling

This commit is contained in:
Chris Lu 2020-05-26 00:03:44 -07:00
parent 5d3ec22975
commit ef2b3a0801
2 changed files with 7 additions and 3 deletions

View file

@ -53,9 +53,11 @@ func (store *LevelDBStore) initialize(dir string) (err error) {
if errors.IsCorrupted(err) { if errors.IsCorrupted(err) {
store.db, err = leveldb.RecoverFile(dir, opts) store.db, err = leveldb.RecoverFile(dir, opts)
} }
if err != nil {
glog.Infof("filer store open dir %s: %v", dir, err) glog.Infof("filer store open dir %s: %v", dir, err)
return return
} }
}
return return
} }

View file

@ -38,8 +38,10 @@ func NewLevelDbNeedleMap(dbFileName string, indexFile *os.File, opts *opt.Option
if errors.IsCorrupted(err) { if errors.IsCorrupted(err) {
m.db, err = leveldb.RecoverFile(dbFileName, opts) m.db, err = leveldb.RecoverFile(dbFileName, opts)
} }
if err != nil {
return return
} }
}
glog.V(1).Infof("Loading %s...", indexFile.Name()) glog.V(1).Infof("Loading %s...", indexFile.Name())
mm, indexLoadError := newNeedleMapMetricFromIndexFile(indexFile) mm, indexLoadError := newNeedleMapMetricFromIndexFile(indexFile)
if indexLoadError != nil { if indexLoadError != nil {