From 3e7db32505895047478731232c9458f00344b08e Mon Sep 17 00:00:00 2001 From: Bilal Akhtar Date: Thu, 12 Sep 2019 15:56:04 -0400 Subject: [PATCH] cli: Add 'pebble' debug command to run Pebble tool commands Command-ception: Add a `debug pebble` command similar to `debug rocksdb` that nests pebble commands like sstable scan, manifest dump, etc right in the cockroach binary. Also move the pebble.Compare definition to engine, which is a more fitting place for it than bulk. Fixes #40509 Release note: None --- Gopkg.lock | 5 ++++- pkg/cli/debug.go | 22 ++++++++++++++++++++ pkg/storage/bulk/sst_writer.go | 35 +------------------------------ pkg/storage/engine/mvcc.go | 38 ++++++++++++++++++++++++++++++++++ vendor | 2 +- 5 files changed, 66 insertions(+), 36 deletions(-) diff --git a/Gopkg.lock b/Gopkg.lock index 63a79718a1f3..f0c78cfb5481 100644 --- a/Gopkg.lock +++ b/Gopkg.lock @@ -427,10 +427,11 @@ [[projects]] branch = "master" - digest = "1:b9896d01af74ea562a587ee910c31e4cc4151c776e2b1b432cf0e91fa210c1ba" + digest = "1:5383a8e64e32447573bf967ea4158a6c0fb9b76a762fc6a535afa58e1577950b" name = "github.com/cockroachdb/pebble" packages = [ ".", + "bloom", "cache", "internal/arenaskl", "internal/base", @@ -444,6 +445,7 @@ "internal/rawalloc", "internal/record", "sstable", + "tool", "vfs", ] pruneopts = "UT" @@ -1952,6 +1954,7 @@ "github.com/cockroachdb/pebble", "github.com/cockroachdb/pebble/cache", "github.com/cockroachdb/pebble/sstable", + "github.com/cockroachdb/pebble/tool", "github.com/cockroachdb/pebble/vfs", "github.com/cockroachdb/returncheck", "github.com/cockroachdb/stress", diff --git a/pkg/cli/debug.go b/pkg/cli/debug.go index 62cf3f0eb3d5..0d26b79445ea 100644 --- a/pkg/cli/debug.go +++ b/pkg/cli/debug.go @@ -53,6 +53,8 @@ import ( "github.com/cockroachdb/cockroach/pkg/util/sysutil" "github.com/cockroachdb/cockroach/pkg/util/timeutil" "github.com/cockroachdb/cockroach/pkg/util/uuid" + "github.com/cockroachdb/pebble" + "github.com/cockroachdb/pebble/tool" "github.com/gogo/protobuf/jsonpb" "github.com/kr/pretty" "github.com/pkg/errors" @@ -758,6 +760,16 @@ https://github.com/facebook/rocksdb/wiki/Administration-and-Data-Access-Tool#ldb }, } +var debugPebbleCmd = &cobra.Command{ + Use: "pebble [command]", + Short: "run a Pebble tool command", + Long: ` +Allows the use of pebble tools, such as to introspect manifests, SSTables, etc. +'cockroach debug pebble' accepts the same arguments and flags as the 'pebble' +binary. +`, +} + var debugSSTDumpCmd = &cobra.Command{ Use: "sst_dump", Short: "run the RocksDB 'sst_dump' tool", @@ -1303,6 +1315,8 @@ var debugCmds = append(DebugCmdsForRocksDB, debugMergeLogsCommand, ) + + // DebugCmd is the root of all debug commands. Exported to allow modification by CCL code. var DebugCmd = &cobra.Command{ Use: "debug [command]", @@ -1318,6 +1332,14 @@ process that has failed and cannot restart. func init() { DebugCmd.AddCommand(debugCmds...) + pebbleTool := tool.New() + merger := *pebble.DefaultMerger + merger.Name = "cockroach_merge_operator" + pebbleTool.RegisterMerger(&merger) + pebbleTool.RegisterComparer(engine.MVCCComparer) + debugPebbleCmd.AddCommand(pebbleTool.Commands...) + DebugCmd.AddCommand(debugPebbleCmd) + f := debugSyncBenchCmd.Flags() f.IntVarP(&syncBenchOpts.Concurrency, "concurrency", "c", syncBenchOpts.Concurrency, "number of concurrent writers") diff --git a/pkg/storage/bulk/sst_writer.go b/pkg/storage/bulk/sst_writer.go index e51b40992f8a..3e0dd0237b28 100644 --- a/pkg/storage/bulk/sst_writer.go +++ b/pkg/storage/bulk/sst_writer.go @@ -30,39 +30,6 @@ type SSTWriter struct { scratch []byte } -var mvccComparer = &pebble.Comparer{ - Compare: engine.MVCCKeyCompare, - AbbreviatedKey: func(k []byte) uint64 { - key, _, ok := enginepb.SplitMVCCKey(k) - if !ok { - return 0 - } - return pebble.DefaultComparer.AbbreviatedKey(key) - }, - - Separator: func(dst, a, b []byte) []byte { - return append(dst, a...) - }, - - Successor: func(dst, a []byte) []byte { - return append(dst, a...) - }, - Split: func(k []byte) int { - if len(k) == 0 { - return len(k) - } - // This is similar to what enginepb.SplitMVCCKey does. - tsLen := int(k[len(k)-1]) - keyPartEnd := len(k) - 1 - tsLen - if keyPartEnd < 0 { - return len(k) - } - return keyPartEnd - }, - - Name: "cockroach_comparator", -} - // timeboundPropCollector implements a property collector for MVCC Timestamps. // Its behavior matches TimeBoundTblPropCollector in table_props.cc. type timeboundPropCollector struct { @@ -126,7 +93,7 @@ var pebbleOpts = func() *pebble.Options { merger.Name = "nullptr" opts := &pebble.Options{ TableFormat: pebble.TableFormatLevelDB, - Comparer: mvccComparer, + Comparer: engine.MVCCComparer, Merger: &merger, } opts.EnsureDefaults() diff --git a/pkg/storage/engine/mvcc.go b/pkg/storage/engine/mvcc.go index b6b7f0b0f620..db1bcab2f92b 100644 --- a/pkg/storage/engine/mvcc.go +++ b/pkg/storage/engine/mvcc.go @@ -26,6 +26,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/util/log" "github.com/cockroachdb/cockroach/pkg/util/protoutil" "github.com/cockroachdb/cockroach/pkg/util/timeutil" + "github.com/cockroachdb/pebble" "github.com/pkg/errors" ) @@ -1861,6 +1862,43 @@ func mvccInitPutUsingIter( }) } +// MVCCComparer is a pebble.Comparer object that implements MVCC-specific +// comparator settings for use with Pebble. +// +// TODO(itsbilal): Move this to a new file pebble.go. +var MVCCComparer = &pebble.Comparer{ + Compare: MVCCKeyCompare, + AbbreviatedKey: func(k []byte) uint64 { + key, _, ok := enginepb.SplitMVCCKey(k) + if !ok { + return 0 + } + return pebble.DefaultComparer.AbbreviatedKey(key) + }, + + Separator: func(dst, a, b []byte) []byte { + return append(dst, a...) + }, + + Successor: func(dst, a []byte) []byte { + return append(dst, a...) + }, + Split: func(k []byte) int { + if len(k) == 0 { + return len(k) + } + // This is similar to what enginepb.SplitMVCCKey does. + tsLen := int(k[len(k)-1]) + keyPartEnd := len(k) - 1 - tsLen + if keyPartEnd < 0 { + return len(k) + } + return keyPartEnd + }, + + Name: "cockroach_comparator", +} + // MVCCMerge implements a merge operation. Merge adds integer values, // concatenates undifferentiated byte slice values, and efficiently // combines time series observations if the roachpb.Value tag value diff --git a/vendor b/vendor index 79ace20395e8..687a9f8951e7 160000 --- a/vendor +++ b/vendor @@ -1 +1 @@ -Subproject commit 79ace20395e8bf2a2d83f76d1eb1a2f5fc1535d7 +Subproject commit 687a9f8951e7271815f2dccfeb27a566cc78e6ff