From 76f436c09be17294f1c1f71632651810d403990a Mon Sep 17 00:00:00 2001 From: Benjamin Wang Date: Wed, 18 Dec 2024 15:18:38 +0000 Subject: [PATCH] Fix the usage of --start-index in etcd-dump-logs Currently if users explicitly set --start-index=0, it will be ignored. It isn't expected, we should respect it as long as users explicitly set it. Signed-off-by: Benjamin Wang --- tools/etcd-dump-logs/main.go | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/tools/etcd-dump-logs/main.go b/tools/etcd-dump-logs/main.go index 72332e397bf..f0bba446762 100644 --- a/tools/etcd-dump-logs/main.go +++ b/tools/etcd-dump-logs/main.go @@ -74,8 +74,15 @@ and output a hex encoded line of binary for each input line`) log.Fatal("start-snap and start-index flags cannot be used together.") } + startFromIndex := false + flag.Visit(func(f *flag.Flag) { + if f.Name == "start-index" { + startFromIndex = true + } + }) + if !*raw { - ents := readUsingReadAll(lg, index, snapfile, dataDir, waldir) + ents := readUsingReadAll(lg, startFromIndex, index, snapfile, dataDir, waldir) fmt.Printf("WAL entries: %d\n", len(ents)) if len(ents) > 0 { @@ -104,16 +111,14 @@ and output a hex encoded line of binary for each input line`) } } -func readUsingReadAll(lg *zap.Logger, index *uint64, snapfile *string, dataDir string, waldir *string) []raftpb.Entry { +func readUsingReadAll(lg *zap.Logger, startFromIndex bool, index *uint64, snapfile *string, dataDir string, waldir *string) []raftpb.Entry { var ( walsnap walpb.Snapshot snapshot *raftpb.Snapshot err error ) - isIndex := *index != 0 - - if isIndex { + if startFromIndex { fmt.Printf("Start dumping log entries from index %d.\n", *index) walsnap.Index = *index } else { @@ -154,7 +159,7 @@ func readUsingReadAll(lg *zap.Logger, index *uint64, snapfile *string, dataDir s } wmetadata, state, ents, err := w.ReadAll() w.Close() - if err != nil && (!isIndex || !errors.Is(err, wal.ErrSnapshotNotFound)) { + if err != nil && (!startFromIndex || !errors.Is(err, wal.ErrSnapshotNotFound)) { log.Fatalf("Failed reading WAL: %v", err) } id, cid := parseWALMetadata(wmetadata)