Browse Source

Merge pull request #10122 from jingyih/cherry-pick-of-#10109-origin-release-3.3

etcdctl: cherry pick of #10109 to release-3.3
Gyuho Lee 7 years ago
parent
commit
40ed18a457
1 changed files with 8 additions and 0 deletions
  1. 8 0
      etcdctl/ctlv3/command/snapshot_command.go

+ 8 - 0
etcdctl/ctlv3/command/snapshot_command.go

@@ -423,6 +423,14 @@ func dbStatus(p string) dbstatus {
 	h := crc32.New(crc32.MakeTable(crc32.Castagnoli))
 
 	err = db.View(func(tx *bolt.Tx) error {
+		// check snapshot file integrity first
+		var dbErrStrings []string
+		for dbErr := range tx.Check() {
+			dbErrStrings = append(dbErrStrings, dbErr.Error())
+		}
+		if len(dbErrStrings) > 0 {
+			return fmt.Errorf("snapshot file integrity check failed. %d errors found.\n"+strings.Join(dbErrStrings, "\n"), len(dbErrStrings))
+		}
 		ds.TotalSize = tx.Size()
 		c := tx.Cursor()
 		for next, _ := c.First(); next != nil; next, _ = c.Next() {