mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2024-12-26 08:35:17 +00:00
1767 lines
55 KiB
Plaintext
1767 lines
55 KiB
Plaintext
|
|
define
|
|
L0
|
|
000009:a.SET.10-b.SET.10
|
|
000007:c.SET.6-d.SET.8
|
|
000003:e.SET.5-j.SET.7
|
|
----
|
|
file count: 3, sublevels: 1, intervals: 6
|
|
flush split keys(3): [b, d, j]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.0, 1, interval range: [0, 4]
|
|
000009:[a#10,1-b#10,1]
|
|
000007:[c#6,1-d#8,1]
|
|
000003:[e#5,1-j#7,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.0: a---b c---d e---------------j
|
|
aa bb cc dd ee ff gg hh ii jj
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
a-c
|
|
aa-cc
|
|
f-g
|
|
e-j
|
|
----
|
|
a-b, c-d, e-j
|
|
a-b, c-d
|
|
a-b, c-d
|
|
e-j
|
|
e-j
|
|
|
|
define
|
|
L0
|
|
000009:a.SET.10-b.SET.10
|
|
000007:b.SET.6-j.SET.8
|
|
000003:e.SET.5-j.SET.7
|
|
----
|
|
file count: 3, sublevels: 3, intervals: 5
|
|
flush split keys(2): [b, j]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000009:[a#10,1-b#10,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [1, 3]
|
|
000007:[b#6,1-j#8,1]
|
|
0.0: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [3, 3]
|
|
000003:[e#5,1-j#7,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: a---b
|
|
L0.1: b------------------------j
|
|
L0.0: e---------------j
|
|
aa bb cc dd ee ff gg hh ii jj
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
a-b
|
|
a-aa
|
|
b-bb
|
|
b-j
|
|
j-j
|
|
----
|
|
a-j
|
|
a-j
|
|
a-b
|
|
b-j
|
|
b-j
|
|
e-j
|
|
|
|
define no_initialize
|
|
L0.2
|
|
000009:a.SET.10-b.SET.10
|
|
L0.1
|
|
000003:e.SET.5-j.SET.7
|
|
L0.0
|
|
000007:b.SET.6-j.SET.8
|
|
----
|
|
file count: 3, sublevels: 3, intervals: 0
|
|
flush split keys(0): []
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000009:[a#10,1-b#10,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000003:[e#5,1-j#7,1]
|
|
0.0: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000007:[b#6,1-j#8,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: a---b
|
|
L0.1: e---------------j
|
|
L0.0: b------------------------j
|
|
aa bb cc dd ee ff gg hh ii jj
|
|
|
|
l0-check-ordering
|
|
----
|
|
OK
|
|
|
|
define no_initialize
|
|
L0.1
|
|
000009:a.SET.10-b.SET.10
|
|
L0.0
|
|
000007:b.SET.6-j.SET.8
|
|
000003:e.SET.5-j.SET.7
|
|
----
|
|
file count: 3, sublevels: 2, intervals: 0
|
|
flush split keys(0): []
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000009:[a#10,1-b#10,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000007:[b#6,1-j#8,1]
|
|
000003:[e#5,1-j#7,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.1: a---b
|
|
L0.0: b------------------------j e---j
|
|
aa bb cc dd ee ff gg hh ii jj
|
|
|
|
l0-check-ordering
|
|
----
|
|
L0.0 files 000007 and 000003 have overlapping ranges: [b#6,SET-j#8,SET] vs [e#5,SET-j#7,SET]
|
|
|
|
define
|
|
L0
|
|
000001:a.SET.2-b.SET.3
|
|
000002:c.SET.3-d.SET.5
|
|
000003:e.SET.5-f.SET.7
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.10-i.SET.10
|
|
000010:f.SET.11-g.SET.11
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 5, intervals: 10
|
|
flush split keys(3): [d, f, g]
|
|
0.4: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [5, 6]
|
|
000010:[f#11,1-g#11,1]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [5, 8]
|
|
000009:[f#10,1-i#10,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [5, 7]
|
|
000005:[f#6,1-h#9,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [4, 5]
|
|
000003:[e#5,1-f#7,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.3, 2, interval range: [0, 6]
|
|
000001:[a#2,1-b#3,1]
|
|
000002:[c#3,1-d#5,1]
|
|
000006:[f#4,1-g#5,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.4: f---g
|
|
L0.3: f---------i
|
|
L0.2: f------h
|
|
L0.1: e---f
|
|
L0.0: a---b c---d f---g
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
max-depth-after-ongoing-compactions
|
|
----
|
|
5
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 5
|
|
000006,000003,000005,000009,000010,000001,000002
|
|
seed interval: f-f
|
|
L0.4: f+++g
|
|
L0.3: f+++++++++i
|
|
L0.2: f++++++h
|
|
L0.1: e+++f
|
|
L0.0: a+++b c+++d f+++g
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# SSTables 000001 and 000002 are optional additions to the above compaction, as they
|
|
# overlap with base files that overlap with L0 files in the seed interval.
|
|
# Marking 0002 as compacting should be enough to exclude both from the
|
|
# chosen compaction.
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
----
|
|
a-b, c-d, e-i
|
|
|
|
define
|
|
L0
|
|
000001:a.SET.2-b.SET.3
|
|
000002:c.SET.3-d.SET.5 intra_l0_compacting
|
|
000003:e.SET.5-f.SET.7
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.10-i.SET.10
|
|
000010:f.SET.11-g.SET.11
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 5, intervals: 10
|
|
flush split keys(3): [d, f, g]
|
|
0.4: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [5, 6]
|
|
000010:[f#11,1-g#11,1]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [5, 8]
|
|
000009:[f#10,1-i#10,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [5, 7]
|
|
000005:[f#6,1-h#9,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [4, 5]
|
|
000003:[e#5,1-f#7,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.3, 2, interval range: [0, 6]
|
|
000001:[a#2,1-b#3,1]
|
|
000002:[c#3,1-d#5,1]
|
|
000006:[f#4,1-g#5,1]
|
|
compacting file count: 1, base compacting intervals: none
|
|
L0.4: f---g
|
|
L0.3: f---------i
|
|
L0.2: f------h
|
|
L0.1: e---f
|
|
L0.0: a---b c^^^d f---g
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 5
|
|
000006,000003,000005,000009,000010
|
|
seed interval: f-f
|
|
L0.4: f+++g
|
|
L0.3: f+++++++++i
|
|
L0.2: f++++++h
|
|
L0.1: e+++f
|
|
L0.0: a---b c^^^d f+++g
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# Mark the above compaction as started.
|
|
|
|
update-state-for-compaction files=(000006,000003,000005,000009,000010)
|
|
----
|
|
OK
|
|
|
|
describe
|
|
----
|
|
file count: 7, sublevels: 5, intervals: 10
|
|
flush split keys(3): [d, f, g]
|
|
0.4: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [5, 6]
|
|
000010:[f#11,1-g#11,1]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [5, 8]
|
|
000009:[f#10,1-i#10,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [5, 7]
|
|
000005:[f#6,1-h#9,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [4, 5]
|
|
000003:[e#5,1-f#7,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.3, 2, interval range: [0, 6]
|
|
000001:[a#2,1-b#3,1]
|
|
000002:[c#3,1-d#5,1]
|
|
000006:[f#4,1-g#5,1]
|
|
compacting file count: 6, base compacting intervals: [4, 9]
|
|
L0.4: fvvvg
|
|
L0.3: fvvvvvvvvvi
|
|
L0.2: fvvvvvvh
|
|
L0.1: evvvf
|
|
L0.0: a---b c^^^d fvvvg
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
no compaction picked
|
|
|
|
# Extend one of the SSTables (000009) to the right, and place an SSTable "under"
|
|
# the extension (000011). This adds it to the compaction.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.10-p.SET.10
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#10,1-p#10,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: f---g
|
|
L0.2: f------------------------------p
|
|
L0.1: f------h
|
|
L0.0: f---g n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
----
|
|
f-p
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000006,000005,000009,000011,000010
|
|
seed interval: f-g
|
|
L0.3: f+++g
|
|
L0.2: f++++++++++++++++++++++++++++++p
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# Set SSTable 000011 which is under/older SSTable 000009 to IsBaseCompacting = true.
|
|
# This should prevent SSTable 000009 from participating in a base compaction.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.10-p.SET.10
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.9 base_compacting
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#10,1-p#10,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#9,1]
|
|
compacting file count: 1, base compacting intervals: [3, 4]
|
|
L0.3: f---g
|
|
L0.2: f------------------------------p
|
|
L0.1: f------h
|
|
L0.0: f---g nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
no compaction picked
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000010,000009,000005,000006
|
|
seed interval: f-g
|
|
L0.3: f+++g
|
|
L0.2: f++++++++++++++++++++++++++++++p
|
|
L0.1: f++++++h
|
|
L0.0: f+++g nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# Raise 000009 to a higher level, so that there's still a stack depth of 3 below
|
|
# it. This should make f-g a candidate for base compaction again.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10 base_compacting
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 1, base compacting intervals: [3, 4]
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000006,000005,000010
|
|
seed interval: f-g
|
|
L0.3: f------------------------------p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
max-depth-after-ongoing-compactions
|
|
----
|
|
4
|
|
|
|
# Assume the above base compaction is chosen. This should reduce max depth after
|
|
# ongoing compactions.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9 base_compacting
|
|
000006:f.SET.4-g.SET.5 base_compacting
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11 base_compacting
|
|
000011:n.SET.8-p.SET.10 base_compacting
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 4, base compacting intervals: [0, 1], [3, 4]
|
|
L0.3: f------------------------------p
|
|
L0.2: fvvvg
|
|
L0.1: fvvvvvvh
|
|
L0.0: fvvvg nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
no compaction picked
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
no compaction picked
|
|
|
|
max-depth-after-ongoing-compactions
|
|
----
|
|
1
|
|
|
|
# Ensure that when 000011 is not base compacting, it's chosen for compactions
|
|
# along with 000009.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000006,000005,000010,000009,000011
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006,000011
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# Don't pick a base compaction if the overlapping Lbase files are marked as
|
|
# compacting.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0 compacting
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g n------p
|
|
L6: a---------------f g====================================s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
no compaction picked
|
|
|
|
# Greatly increase the size of SSTable 000009, past 100 << 20. This should make
|
|
# it no longer a candidate for base compaction.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.12-p.SET.12 size=104859600
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(4): [g, h, n, p]
|
|
0.3: file count: 1, bytes: 104859600, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000006,000005,000010,000011
|
|
seed interval: f-g
|
|
L0.3: f------------------------------p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006,000011
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# However, when the size increase is applied to a lower sublevel that is
|
|
# necessary to include to meet the minimum stack depth reduction, we overlook
|
|
# the size difference and choose the file for compaction anyway.
|
|
|
|
define
|
|
L0
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11 size=104859600
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 5, sublevels: 4, intervals: 5
|
|
flush split keys(2): [g, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [0, 3]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 104859600, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 3]
|
|
000006:[f#4,1-g#5,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000006,000005,000010,000009,000011
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006,000011
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
read-amp
|
|
----
|
|
4
|
|
|
|
# In L0.0, SST 000007 is marked as base compacting. There are two SSTs to the left
|
|
# of it in the sublevel, and one to its right. The ones to its left should be
|
|
# chosen by extendCandidateToRectangle.
|
|
|
|
define
|
|
L0
|
|
000004:h.SET.2-j.SET.4
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000007:k.SET.2-l.SET.4 base_compacting
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000012:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 4, intervals: 9
|
|
flush split keys(4): [g, h, l, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 8.0, 8, interval range: [0, 7]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [0, 2]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 1.2, 2, interval range: [0, 7]
|
|
000006:[f#4,1-g#5,1]
|
|
000004:[h#2,1-j#4,1]
|
|
000007:[k#2,1-l#4,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 1, base compacting intervals: [5, 5]
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g h------j kvvvl n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006,000004
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g h++++++j kvvvl n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000006,000005,000004,000010
|
|
seed interval: f-g
|
|
L0.3: f------------------------------p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g h++++++j kvvvl n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
|
|
# Now shift the base_compacting marker one SST to the left. But since file 6
|
|
# was already chosen as part of the seed compaction construction, we still
|
|
# prefer to choose it over files 7 and 11.
|
|
|
|
define
|
|
L0
|
|
000004:h.SET.2-j.SET.4 base_compacting
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000007:k.SET.2-l.SET.4
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000012:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 4, intervals: 9
|
|
flush split keys(4): [g, h, l, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 8.0, 8, interval range: [0, 7]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [0, 2]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 1.2, 2, interval range: [0, 7]
|
|
000006:[f#4,1-g#5,1]
|
|
000004:[h#2,1-j#4,1]
|
|
000007:[k#2,1-l#4,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 1, base compacting intervals: [2, 3]
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g hvvvvvvj k---l n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g hvvvvvvj k---l n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# Without any base_compacting markers, all SSTs in the bottom sublevel should
|
|
# be chosen for an intra-L0 compaction.
|
|
|
|
define
|
|
L0
|
|
000004:h.SET.2-j.SET.4
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000007:k.SET.2-l.SET.4
|
|
000009:f.SET.12-p.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10
|
|
L6
|
|
000012:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 4, intervals: 9
|
|
flush split keys(4): [g, h, l, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 8.0, 8, interval range: [0, 7]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [0, 2]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 1.2, 2, interval range: [0, 7]
|
|
000006:[f#4,1-g#5,1]
|
|
000004:[h#2,1-j#4,1]
|
|
000007:[k#2,1-l#4,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: f------------------------------p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: f---g h------j k---l n------p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-intra-l0-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000009,000010,000005,000006,000004,000007,000011
|
|
seed interval: f-g
|
|
L0.3: f++++++++++++++++++++++++++++++p
|
|
L0.2: f+++g
|
|
L0.1: f++++++h
|
|
L0.0: f+++g h++++++j k+++l n++++++p
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
define flush_split_max_bytes=32
|
|
L0
|
|
000001:a.SET.2-e.SET.5 size=64
|
|
000002:c.SET.6-g.SET.8 size=16
|
|
000003:f.SET.9-j.SET.11 size=16
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 3, sublevels: 3, intervals: 6
|
|
flush split keys(0): []
|
|
0.2: file count: 1, bytes: 16, width (mean, max): 2.0, 2, interval range: [3, 4]
|
|
000003:[f#9,1-j#11,1]
|
|
0.1: file count: 1, bytes: 16, width (mean, max): 3.0, 3, interval range: [1, 3]
|
|
000002:[c#6,1-g#8,1]
|
|
0.0: file count: 1, bytes: 64, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000001:[a#2,1-e#5,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: f------------j
|
|
L0.1: c------------g
|
|
L0.0: a------------e
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
# Check that read amplification is the sublevel height of the tallest key
|
|
# interval, not the overall count of sublevels.
|
|
|
|
read-amp
|
|
----
|
|
2
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
----
|
|
a-j
|
|
|
|
# The comparison of a cumulative count of interpolated bytes and
|
|
# flushSplitMaxBytes is a <, so even though the cumulative count equals 32 after
|
|
# a-c, we do not emit a flush split key until the end of the next interval, c-e.
|
|
|
|
flush-split-keys
|
|
----
|
|
flush user split keys: none
|
|
|
|
# Reduce flush_split_max_bytes by 1, and there should also be a split key at c.
|
|
|
|
define flush_split_max_bytes=31
|
|
L0
|
|
000001:a.SET.2-e.SET.5 size=64
|
|
000002:c.SET.6-g.SET.8 size=16
|
|
000003:f.SET.9-j.SET.11 size=16
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 3, sublevels: 3, intervals: 6
|
|
flush split keys(1): [j]
|
|
0.2: file count: 1, bytes: 16, width (mean, max): 2.0, 2, interval range: [3, 4]
|
|
000003:[f#9,1-j#11,1]
|
|
0.1: file count: 1, bytes: 16, width (mean, max): 3.0, 3, interval range: [1, 3]
|
|
000002:[c#6,1-g#8,1]
|
|
0.0: file count: 1, bytes: 64, width (mean, max): 2.0, 2, interval range: [0, 1]
|
|
000001:[a#2,1-e#5,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: f------------j
|
|
L0.1: c------------g
|
|
L0.0: a------------e
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
flush-split-keys
|
|
----
|
|
flush user split keys: j
|
|
|
|
max-depth-after-ongoing-compactions
|
|
----
|
|
2
|
|
|
|
define flush_split_max_bytes=64
|
|
L0
|
|
000001:a.SET.2-d.SET.5 size=64
|
|
000002:e.SET.6-g.SET.8 size=64
|
|
000003:h.SET.9-j.SET.11 size=16
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 3, sublevels: 1, intervals: 6
|
|
flush split keys(1): [g]
|
|
0.0: file count: 3, bytes: 144, width (mean, max): 1.0, 1, interval range: [0, 4]
|
|
000001:[a#2,1-d#5,1]
|
|
000002:[e#6,1-g#8,1]
|
|
000003:[h#9,1-j#11,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.0: a---------d e------g h------j
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
flush-split-keys
|
|
----
|
|
flush user split keys: g
|
|
|
|
# The calculation for flush split bytes multiplies the specified max bytes
|
|
# parameter with the number of sublevels. In the case below, that should mean
|
|
# a flush split key would not be emitted at d despite the estimated bytes tally
|
|
# exceeding 64 bytes. Instead, it would be emitted when 64 * 2 = 128 bytes have
|
|
# been exceeded.
|
|
|
|
define flush_split_max_bytes=64
|
|
L0
|
|
000001:a.SET.2-d.SET.5 size=64
|
|
000004:d.SET.12-e.SET.12 size=64
|
|
000002:e.SET.6-g.SET.8 size=64
|
|
000003:h.SET.9-j.SET.11 size=16
|
|
L6
|
|
000007:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 4, sublevels: 2, intervals: 8
|
|
flush split keys(1): [e]
|
|
0.1: file count: 1, bytes: 64, width (mean, max): 3.0, 3, interval range: [1, 3]
|
|
000004:[d#12,1-e#12,1]
|
|
0.0: file count: 3, bytes: 144, width (mean, max): 1.7, 2, interval range: [0, 6]
|
|
000001:[a#2,1-d#5,1]
|
|
000002:[e#6,1-g#8,1]
|
|
000003:[h#9,1-j#11,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.1: d---e
|
|
L0.0: a---------d e------g h------j
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
in-use-key-ranges
|
|
b-b
|
|
dd-e
|
|
dd-i
|
|
dd-h
|
|
dd-j
|
|
dd-s
|
|
----
|
|
a-d
|
|
d-g
|
|
d-g, h-j
|
|
d-g, h-j
|
|
d-g, h-j
|
|
d-g, h-j
|
|
|
|
flush-split-keys
|
|
----
|
|
flush user split keys: e
|
|
|
|
# Ensure that the compaction picker doesn't error out when all seed files are
|
|
# compacting.
|
|
|
|
define
|
|
L0
|
|
000004:h.SET.2-j.SET.4 base_compacting
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5 base_compacting
|
|
000007:k.SET.2-l.SET.4 base_compacting
|
|
000009:f.SET.12-p.SET.12 intra_l0_compacting
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-p.SET.10 base_compacting
|
|
L6
|
|
000012:a.SET.0-f.SET.0
|
|
000008:g.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 4, intervals: 9
|
|
flush split keys(4): [g, h, l, p]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 8.0, 8, interval range: [0, 7]
|
|
000009:[f#12,1-p#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [0, 2]
|
|
000005:[f#6,1-h#9,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 1.2, 2, interval range: [0, 7]
|
|
000006:[f#4,1-g#5,1]
|
|
000004:[h#2,1-j#4,1]
|
|
000007:[k#2,1-l#4,1]
|
|
000011:[n#8,1-p#10,1]
|
|
compacting file count: 5, base compacting intervals: [0, 0], [2, 3], [5, 5], [7, 8]
|
|
L0.3: f^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^p
|
|
L0.2: f---g
|
|
L0.1: f------h
|
|
L0.0: fvvvg hvvvvvvj kvvvl nvvvvvvp
|
|
L6: a---------------f g------------------------------------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=2
|
|
----
|
|
no compaction picked
|
|
|
|
pick-intra-l0-compaction min_depth=2
|
|
----
|
|
no compaction picked
|
|
|
|
# Ensure that base files with largest key set to the rangedel sentinel key are
|
|
# treated as not containing the largest user key. If L0 files containing that
|
|
# user key get added to that compaction, it could trigger a
|
|
# "files have overlapping ranges" error in Lbase as one of the outputs of the
|
|
# compaction would overlap with an Lbase file not in the compaction.
|
|
# Compare the output of the next two calls to PickBaseCompaction below; as the
|
|
# base file's end key is changed to the range deletion sentinel, L0 files
|
|
# overlapping with it are no longer chosen for compaction.
|
|
|
|
define
|
|
L0
|
|
000004:h.SET.2-j.SET.4
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000007:k.SET.2-l.SET.4
|
|
000009:n.SET.12-o.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-o.SET.10
|
|
L6
|
|
000001:a.SET.0-o.SET.0
|
|
000008:p.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 3, intervals: 9
|
|
flush split keys(4): [g, h, l, o]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 2, bytes: 512, width (mean, max): 2.0, 3, interval range: [0, 7]
|
|
000005:[f#6,1-h#9,1]
|
|
000009:[n#12,1-o#12,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 1.2, 2, interval range: [0, 7]
|
|
000006:[f#4,1-g#5,1]
|
|
000004:[h#2,1-j#4,1]
|
|
000007:[k#2,1-l#4,1]
|
|
000011:[n#8,1-o#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: f---g
|
|
L0.1: f------h n---o
|
|
L0.0: f---g h------j k---l n---o
|
|
L6: a------------------------------------------o p---------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=2
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000006,000005,000004,000010,000007,000011,000009
|
|
seed interval: f-g
|
|
L0.2: f+++g
|
|
L0.1: f++++++h n+++o
|
|
L0.0: f+++g h++++++j k+++l n+++o
|
|
L6: a------------------------------------------o p---------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
define
|
|
L0
|
|
000004:h.SET.2-j.SET.4
|
|
000005:f.SET.6-h.SET.9
|
|
000006:f.SET.4-g.SET.5
|
|
000007:k.SET.2-l.SET.4
|
|
000009:n.SET.12-o.SET.12
|
|
000010:f.SET.11-g.SET.11
|
|
000011:n.SET.8-o.SET.10
|
|
L6
|
|
000001:a.SET.0-o.RANGEDEL.72057594037927935
|
|
000008:p.SET.0-s.SET.0
|
|
----
|
|
file count: 7, sublevels: 3, intervals: 9
|
|
flush split keys(4): [g, h, l, o]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000010:[f#11,1-g#11,1]
|
|
0.1: file count: 2, bytes: 512, width (mean, max): 2.0, 3, interval range: [0, 7]
|
|
000005:[f#6,1-h#9,1]
|
|
000009:[n#12,1-o#12,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 1.2, 2, interval range: [0, 7]
|
|
000006:[f#4,1-g#5,1]
|
|
000004:[h#2,1-j#4,1]
|
|
000007:[k#2,1-l#4,1]
|
|
000011:[n#8,1-o#10,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: f---g
|
|
L0.1: f------h n---o
|
|
L0.0: f---g h------j k---l n---o
|
|
L6: a------------------------------------------o p---------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
pick-base-compaction min_depth=2
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000006,000005,000004,000010,000007,000011,000009
|
|
seed interval: f-g
|
|
L0.2: f+++g
|
|
L0.1: f++++++h n+++o
|
|
L0.0: f+++g h++++++j k+++l n+++o
|
|
L6: a------------------------------------------o p---------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
n-o
|
|
----
|
|
f-j, k-l, n-o
|
|
n-o
|
|
|
|
# Ensure that two L0 sstables where one ends at a rangedel sentinel key and
|
|
# the other starts at the same user key occupy the same sublevel.
|
|
|
|
define
|
|
L0
|
|
000004:a.SET.2-d.RANGEDEL.72057594037927935
|
|
000005:d.SET.3-g.SET.5
|
|
L6
|
|
000001:a.SET.0-o.SET.0
|
|
000008:p.SET.0-s.SET.0
|
|
----
|
|
file count: 2, sublevels: 1, intervals: 3
|
|
flush split keys(2): [d, g]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 1]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.0: a--------d---------g
|
|
L6: a------------------------------------------o p---------s
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
a-g
|
|
b-c
|
|
----
|
|
a-g
|
|
a-g
|
|
a-d
|
|
|
|
define
|
|
L0
|
|
000004:a.SET.2-d.RANGEDEL.72057594037927935
|
|
000005:d.SET.3-g.SET.5
|
|
000006:f.SET.6-i.SET.6
|
|
000007:h.SET.7-m.SET.7
|
|
000009:q.SET.7-r.SET.7
|
|
000010:g.SET.10-i.SET.10
|
|
----
|
|
file count: 6, sublevels: 4, intervals: 10
|
|
flush split keys(4): [f, g, i, r]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [3, 5]
|
|
000010:[g#10,1-i#10,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [5, 6]
|
|
000007:[h#7,1-m#7,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [2, 5]
|
|
000006:[f#6,1-i#6,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.7, 3, interval range: [0, 8]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
000009:[q#7,1-r#7,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: g------i
|
|
L0.2: h---------------m
|
|
L0.1: f---------i
|
|
L0.0: a--------d---------g q---r
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr
|
|
|
|
in-use-key-ranges
|
|
f-m
|
|
f-n
|
|
f-l
|
|
ff-m
|
|
ff-n
|
|
ff-l
|
|
----
|
|
f-m
|
|
f-m
|
|
f-m
|
|
f-m
|
|
f-m
|
|
f-m
|
|
|
|
in-use-key-ranges
|
|
n-o
|
|
m-q
|
|
l-qq
|
|
----
|
|
.
|
|
i-m, q-r
|
|
i-m, q-r
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
g-l
|
|
----
|
|
a-m, q-r
|
|
g-m
|
|
|
|
in-use-key-ranges
|
|
a-ff
|
|
a-gg
|
|
a-i
|
|
d-d
|
|
----
|
|
a-g
|
|
a-i
|
|
a-m
|
|
d-g
|
|
|
|
# Same example as above, except we incrementally add the sublevels. The output
|
|
# of in-use-key-ranges must be the same.
|
|
|
|
define
|
|
L0
|
|
000004:a.SET.2-d.RANGEDEL.72057594037927935
|
|
----
|
|
file count: 1, sublevels: 1, intervals: 2
|
|
flush split keys(1): [d]
|
|
0.0: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.0: a---------d
|
|
aa bb cc dd
|
|
|
|
add-l0-files
|
|
000005:d.SET.3-g.SET.5
|
|
----
|
|
file count: 2, sublevels: 1, intervals: 3
|
|
flush split keys(2): [d, g]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.0, 1, interval range: [0, 1]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.0: a--------d---------g
|
|
aa bb cc dd ee ff gg
|
|
|
|
add-l0-files
|
|
000006:f.SET.6-i.SET.6
|
|
----
|
|
file count: 3, sublevels: 2, intervals: 5
|
|
flush split keys(2): [d, g]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [2, 3]
|
|
000006:[f#6,1-i#6,1]
|
|
0.0: file count: 2, bytes: 512, width (mean, max): 1.5, 2, interval range: [0, 2]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.1: f---------i
|
|
L0.0: a--------d---------g
|
|
aa bb cc dd ee ff gg hh ii
|
|
|
|
add-l0-files
|
|
000007:h.SET.7-m.SET.7
|
|
000009:q.SET.8-r.SET.8
|
|
----
|
|
file count: 5, sublevels: 3, intervals: 9
|
|
flush split keys(4): [d, g, i, r]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [4, 5]
|
|
000007:[h#7,1-m#7,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [2, 4]
|
|
000006:[f#6,1-i#6,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.3, 2, interval range: [0, 7]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
000009:[q#8,1-r#8,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.2: h---------------m
|
|
L0.1: f---------i
|
|
L0.0: a--------d---------g q---r
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr
|
|
|
|
# The output below should exactly match the output of the second last define.
|
|
|
|
add-l0-files
|
|
000010:g.SET.10-i.SET.10
|
|
----
|
|
file count: 6, sublevels: 4, intervals: 10
|
|
flush split keys(4): [f, g, i, r]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [3, 5]
|
|
000010:[g#10,1-i#10,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [5, 6]
|
|
000007:[h#7,1-m#7,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 4.0, 4, interval range: [2, 5]
|
|
000006:[f#6,1-i#6,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 1.7, 3, interval range: [0, 8]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
000009:[q#8,1-r#8,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: g------i
|
|
L0.2: h---------------m
|
|
L0.1: f---------i
|
|
L0.0: a--------d---------g q---r
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr
|
|
|
|
in-use-key-ranges
|
|
f-m
|
|
f-n
|
|
f-l
|
|
ff-m
|
|
ff-n
|
|
ff-l
|
|
----
|
|
f-m
|
|
f-m
|
|
f-m
|
|
f-m
|
|
f-m
|
|
f-m
|
|
|
|
in-use-key-ranges
|
|
n-o
|
|
m-q
|
|
l-qq
|
|
----
|
|
.
|
|
i-m, q-r
|
|
i-m, q-r
|
|
|
|
in-use-key-ranges
|
|
a-z
|
|
g-l
|
|
----
|
|
a-m, q-r
|
|
g-m
|
|
|
|
in-use-key-ranges
|
|
a-ff
|
|
a-gg
|
|
a-i
|
|
d-d
|
|
----
|
|
a-g
|
|
a-i
|
|
a-m
|
|
d-g
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000005,000006,000010,000007,000004,000009
|
|
seed interval: g-g
|
|
L0.3: g++++++i
|
|
L0.2: h+++++++++++++++m
|
|
L0.1: f+++++++++i
|
|
L0.0: a++++++++d+++++++++g q+++r
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr
|
|
|
|
# Adding two overlapping L0 files is supported too, as long as they're disjoint
|
|
# in sequence number ranges.
|
|
|
|
add-l0-files
|
|
000011:b.SET.13-e.SET.15
|
|
000012:c.SET.16-e.SET.17
|
|
----
|
|
file count: 8, sublevels: 4, intervals: 13
|
|
flush split keys(5): [d, e, g, i, r]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [6, 8]
|
|
000010:[g#10,1-i#10,1]
|
|
0.2: file count: 2, bytes: 512, width (mean, max): 2.0, 2, interval range: [2, 9]
|
|
000012:[c#16,1-e#17,1]
|
|
000007:[h#7,1-m#7,1]
|
|
0.1: file count: 2, bytes: 512, width (mean, max): 3.5, 4, interval range: [1, 8]
|
|
000011:[b#13,1-e#15,1]
|
|
000006:[f#6,1-i#6,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 2.7, 4, interval range: [0, 11]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
000009:[q#8,1-r#8,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: g------i
|
|
L0.2: c------e h---------------m
|
|
L0.1: b---------e f---------i
|
|
L0.0: a--------d---------g q---r
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr
|
|
|
|
# Multiple sublevels can also be added in one add-l0-files.
|
|
|
|
add-l0-files
|
|
000013:h.SET.18-i.SET.19
|
|
000014:g.SET.20-i.SET.21
|
|
----
|
|
file count: 10, sublevels: 6, intervals: 13
|
|
flush split keys(4): [d, g, h, i]
|
|
0.5: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [6, 8]
|
|
000014:[g#20,1-i#21,1]
|
|
0.4: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [8, 8]
|
|
000013:[h#18,1-i#19,1]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [6, 8]
|
|
000010:[g#10,1-i#10,1]
|
|
0.2: file count: 2, bytes: 512, width (mean, max): 2.0, 2, interval range: [2, 9]
|
|
000012:[c#16,1-e#17,1]
|
|
000007:[h#7,1-m#7,1]
|
|
0.1: file count: 2, bytes: 512, width (mean, max): 3.5, 4, interval range: [1, 8]
|
|
000011:[b#13,1-e#15,1]
|
|
000006:[f#6,1-i#6,1]
|
|
0.0: file count: 3, bytes: 768, width (mean, max): 2.7, 4, interval range: [0, 11]
|
|
000004:[a#2,1-d#72057594037927935,15]
|
|
000005:[d#3,1-g#5,1]
|
|
000009:[q#8,1-r#8,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.5: g------i
|
|
L0.4: h---i
|
|
L0.3: g------i
|
|
L0.2: c------e h---------------m
|
|
L0.1: b---------e f---------i
|
|
L0.0: a--------d---------g q---r
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr
|
|
|
|
# Adding an old L0 file returns an error.
|
|
|
|
add-l0-files
|
|
000015:h.SET.17-i.SET.17
|
|
----
|
|
pebble: L0 sublevel generation optimization cannot be used
|
|
|
|
# The following test cases cover the examples provided in the documentation.
|
|
# NOTE: following initialization, some of the files fall down into lower levels
|
|
# where there is space.
|
|
|
|
# Example 1. No in-progress L0 -> LBase compaction.
|
|
|
|
define
|
|
L0.3
|
|
000011:a.SET.18-d.SET.19
|
|
000012:g.SET.20-j.SET.21
|
|
L0.2
|
|
000009:f.SET.14-j.SET.15
|
|
000010:r.SET.16-t.SET.17
|
|
L0.1
|
|
000007:b.SET.10-d.SET.11
|
|
000008:e.SET.12-j.SET.13
|
|
L0.0
|
|
000003:a.SET.2-d.SET.3
|
|
000004:f.SET.4-j.SET.5
|
|
000005:l.SET.6-o.SET.7
|
|
000006:p.SET.8-x.SET.9
|
|
L6
|
|
000001:a.SET.0-i.SET.0
|
|
000002:m.SET.0-w.SET.0
|
|
----
|
|
file count: 10, sublevels: 4, intervals: 13
|
|
flush split keys(5): [d, g, j, r, t]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [5, 5]
|
|
000012:[g#20,1-j#21,1]
|
|
0.2: file count: 2, bytes: 512, width (mean, max): 2.0, 2, interval range: [0, 5]
|
|
000011:[a#18,1-d#19,1]
|
|
000009:[f#14,1-j#15,1]
|
|
0.1: file count: 3, bytes: 768, width (mean, max): 1.7, 3, interval range: [1, 10]
|
|
000007:[b#10,1-d#11,1]
|
|
000008:[e#12,1-j#13,1]
|
|
000010:[r#16,1-t#17,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 2.0, 3, interval range: [0, 11]
|
|
000003:[a#2,1-d#3,1]
|
|
000004:[f#4,1-j#5,1]
|
|
000005:[l#6,1-o#7,1]
|
|
000006:[p#8,1-x#9,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: g---------j
|
|
L0.2: a---------d f------------j
|
|
L0.1: b------d e---------------j r------t
|
|
L0.0: a---------d f------------j l---------o p------------------------x
|
|
L6: a------------------------i m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
compaction picked with stack depth reduction 4
|
|
000004,000008,000009,000012,000003,000007,000011
|
|
seed interval: g-j
|
|
L0.3: g+++++++++j
|
|
L0.2: a+++++++++d f++++++++++++j
|
|
L0.1: b++++++d e+++++++++++++++j r------t
|
|
L0.0: a+++++++++d f++++++++++++j l---------o p------------------------x
|
|
L6: a------------------------i m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
# Example 2. Left half of the keyspace compacting. Select the "next best"
|
|
# compaction.
|
|
|
|
define
|
|
L0.3
|
|
000011:a.SET.18-d.SET.19 base_compacting
|
|
000012:g.SET.20-j.SET.21 base_compacting
|
|
L0.2
|
|
000009:f.SET.14-j.SET.15 base_compacting
|
|
000010:r.SET.16-t.SET.17
|
|
L0.1
|
|
000007:b.SET.10-d.SET.11 base_compacting
|
|
000008:e.SET.12-j.SET.13 base_compacting
|
|
L0.0
|
|
000003:a.SET.2-d.SET.3 base_compacting
|
|
000004:f.SET.4-j.SET.5 base_compacting
|
|
000005:l.SET.6-o.SET.7
|
|
000006:p.SET.8-x.SET.9
|
|
L6
|
|
000001:a.SET.0-i.SET.0
|
|
000002:m.SET.0-w.SET.0
|
|
----
|
|
file count: 10, sublevels: 4, intervals: 13
|
|
flush split keys(5): [d, g, j, r, t]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [5, 5]
|
|
000012:[g#20,1-j#21,1]
|
|
0.2: file count: 2, bytes: 512, width (mean, max): 2.0, 2, interval range: [0, 5]
|
|
000011:[a#18,1-d#19,1]
|
|
000009:[f#14,1-j#15,1]
|
|
0.1: file count: 3, bytes: 768, width (mean, max): 1.7, 3, interval range: [1, 10]
|
|
000007:[b#10,1-d#11,1]
|
|
000008:[e#12,1-j#13,1]
|
|
000010:[r#16,1-t#17,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 2.0, 3, interval range: [0, 11]
|
|
000003:[a#2,1-d#3,1]
|
|
000004:[f#4,1-j#5,1]
|
|
000005:[l#6,1-o#7,1]
|
|
000006:[p#8,1-x#9,1]
|
|
compacting file count: 7, base compacting intervals: [0, 6]
|
|
L0.3: gvvvvvvvvvj
|
|
L0.2: avvvvvvvvvd fvvvvvvvvvvvvj
|
|
L0.1: bvvvvvvd evvvvvvvvvvvvvvvj r------t
|
|
L0.0: avvvvvvvvvd fvvvvvvvvvvvvj l---------o p------------------------x
|
|
L6: a------------------------i m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
pick-base-compaction min_depth=3
|
|
----
|
|
no compaction picked
|
|
|
|
pick-base-compaction min_depth=2
|
|
----
|
|
compaction picked with stack depth reduction 2
|
|
000006,000010,000005
|
|
seed interval: r-t
|
|
L0.3: gvvvvvvvvvj
|
|
L0.2: avvvvvvvvvd fvvvvvvvvvvvvj
|
|
L0.1: bvvvvvvd evvvvvvvvvvvvvvvj r++++++t
|
|
L0.0: avvvvvvvvvd fvvvvvvvvvvvvj l+++++++++o p++++++++++++++++++++++++x
|
|
L6: a------------------------i m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
# Example 3. The same as Example 2, except there is now an additional file in
|
|
# LBase that overlaps with the [l,o] file in L0.0.
|
|
|
|
define
|
|
L0.3
|
|
000011:a.SET.18-d.SET.19 base_compacting
|
|
000012:g.SET.20-j.SET.21 base_compacting
|
|
L0.2
|
|
000009:f.SET.14-j.SET.15 base_compacting
|
|
000010:r.SET.16-t.SET.17
|
|
L0.1
|
|
000007:b.SET.10-d.SET.11 base_compacting
|
|
000008:e.SET.12-j.SET.13 base_compacting
|
|
L0.0
|
|
000003:a.SET.2-d.SET.3 base_compacting
|
|
000004:f.SET.4-j.SET.5 base_compacting
|
|
000005:l.SET.6-o.SET.7
|
|
000006:p.SET.8-x.SET.9
|
|
L6
|
|
000001:a.SET.0-i.SET.0
|
|
000013:j.SET.0-l.SET.0
|
|
000002:m.SET.0-w.SET.0
|
|
----
|
|
file count: 10, sublevels: 4, intervals: 13
|
|
flush split keys(5): [d, g, j, r, t]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [5, 5]
|
|
000012:[g#20,1-j#21,1]
|
|
0.2: file count: 2, bytes: 512, width (mean, max): 2.0, 2, interval range: [0, 5]
|
|
000011:[a#18,1-d#19,1]
|
|
000009:[f#14,1-j#15,1]
|
|
0.1: file count: 3, bytes: 768, width (mean, max): 1.7, 3, interval range: [1, 10]
|
|
000007:[b#10,1-d#11,1]
|
|
000008:[e#12,1-j#13,1]
|
|
000010:[r#16,1-t#17,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 2.0, 3, interval range: [0, 11]
|
|
000003:[a#2,1-d#3,1]
|
|
000004:[f#4,1-j#5,1]
|
|
000005:[l#6,1-o#7,1]
|
|
000006:[p#8,1-x#9,1]
|
|
compacting file count: 7, base compacting intervals: [0, 6]
|
|
L0.3: gvvvvvvvvvj
|
|
L0.2: avvvvvvvvvd fvvvvvvvvvvvvj
|
|
L0.1: bvvvvvvd evvvvvvvvvvvvvvvj r------t
|
|
L0.0: avvvvvvvvvd fvvvvvvvvvvvvj l---------o p------------------------x
|
|
L6: a------------------------i j------l m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
pick-base-compaction min_depth=2
|
|
----
|
|
compaction picked with stack depth reduction 2
|
|
000006,000010
|
|
seed interval: r-t
|
|
L0.3: gvvvvvvvvvj
|
|
L0.2: avvvvvvvvvd fvvvvvvvvvvvvj
|
|
L0.1: bvvvvvvd evvvvvvvvvvvvvvvj r++++++t
|
|
L0.0: avvvvvvvvvd fvvvvvvvvvvvvj l---------o p++++++++++++++++++++++++x
|
|
L6: a------------------------i j------l m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
# Example 4. Intra-L0 compactions.
|
|
|
|
define
|
|
L0.3
|
|
000011:a.SET.18-d.SET.19
|
|
000012:g.SET.20-j.SET.21 base_compacting
|
|
L0.2
|
|
000009:f.SET.14-j.SET.15 base_compacting
|
|
000010:r.SET.16-t.SET.17 base_compacting
|
|
L0.1
|
|
000007:b.SET.10-d.SET.11
|
|
000008:e.SET.12-j.SET.13 base_compacting
|
|
L0.0
|
|
000003:a.SET.2-d.SET.3
|
|
000004:f.SET.4-j.SET.5 base_compacting
|
|
000005:l.SET.6-o.SET.7
|
|
000006:p.SET.8-x.SET.9 base_compacting
|
|
L6
|
|
000001:a.SET.0-i.SET.0
|
|
000002:m.SET.0-w.SET.0
|
|
----
|
|
file count: 10, sublevels: 4, intervals: 13
|
|
flush split keys(5): [d, g, j, r, t]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [5, 5]
|
|
000012:[g#20,1-j#21,1]
|
|
0.2: file count: 2, bytes: 512, width (mean, max): 2.0, 2, interval range: [0, 5]
|
|
000011:[a#18,1-d#19,1]
|
|
000009:[f#14,1-j#15,1]
|
|
0.1: file count: 3, bytes: 768, width (mean, max): 1.7, 3, interval range: [1, 10]
|
|
000007:[b#10,1-d#11,1]
|
|
000008:[e#12,1-j#13,1]
|
|
000010:[r#16,1-t#17,1]
|
|
0.0: file count: 4, bytes: 1024, width (mean, max): 2.0, 3, interval range: [0, 11]
|
|
000003:[a#2,1-d#3,1]
|
|
000004:[f#4,1-j#5,1]
|
|
000005:[l#6,1-o#7,1]
|
|
000006:[p#8,1-x#9,1]
|
|
compacting file count: 6, base compacting intervals: [3, 6], [9, 12]
|
|
L0.3: gvvvvvvvvvj
|
|
L0.2: a---------d fvvvvvvvvvvvvj
|
|
L0.1: b------d evvvvvvvvvvvvvvvj rvvvvvvt
|
|
L0.0: a---------d fvvvvvvvvvvvvj l---------o pvvvvvvvvvvvvvvvvvvvvvvvvx
|
|
L6: a------------------------i m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
pick-intra-l0-compaction min_depth=2
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000011,000007,000003
|
|
seed interval: b-d
|
|
L0.3: gvvvvvvvvvj
|
|
L0.2: a+++++++++d fvvvvvvvvvvvvj
|
|
L0.1: b++++++d evvvvvvvvvvvvvvvj rvvvvvvt
|
|
L0.0: a+++++++++d fvvvvvvvvvvvvj l---------o pvvvvvvvvvvvvvvvvvvvvvvvvx
|
|
L6: a------------------------i m------------------------------w
|
|
aa bb cc dd ee ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx
|
|
|
|
# Regression test for cockroachdb/cockroach#101896. We must return
|
|
# errInvalidL0SublevelOpt in any case where a new L0 file is being AddL0File'd
|
|
# with a largest sequence number below an existing file in the same interval.
|
|
|
|
define
|
|
L0
|
|
000004:a.SET.2-e.SET.3
|
|
000006:a.SET.7-b.SET.8
|
|
000007:d.SET.12-f.SET.12
|
|
----
|
|
file count: 3, sublevels: 2, intervals: 5
|
|
flush split keys(2): [b, e]
|
|
0.1: file count: 2, bytes: 512, width (mean, max): 1.5, 2, interval range: [0, 3]
|
|
000006:[a#7,1-b#8,1]
|
|
000007:[d#12,1-f#12,1]
|
|
0.0: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [0, 2]
|
|
000004:[a#2,1-e#3,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.1: a---b d------f
|
|
L0.0: a------------e
|
|
aa bb cc dd ee ff
|
|
|
|
# Note that 000006 will bump the sublevel for the incoming file to 2. We
|
|
# should still realize that it's slotting below 000007 and return an error.
|
|
|
|
add-l0-files
|
|
000015:a.SET.9-g.SET.10
|
|
----
|
|
pebble: L0 sublevel generation optimization cannot be used
|
|
|
|
# Fully-regenerated L0 sublevels allow us to pick an intra-L0 compaction that
|
|
# does not violate sublevel ordering.
|
|
|
|
define
|
|
L0
|
|
000004:a.SET.2-e.SET.3
|
|
000006:a.SET.7-b.SET.8
|
|
000007:d.SET.12-f.SET.12
|
|
000015:a.SET.9-g.SET.10
|
|
----
|
|
file count: 4, sublevels: 4, intervals: 6
|
|
flush split keys(2): [b, e]
|
|
0.3: file count: 1, bytes: 256, width (mean, max): 2.0, 2, interval range: [2, 3]
|
|
000007:[d#12,1-f#12,1]
|
|
0.2: file count: 1, bytes: 256, width (mean, max): 5.0, 5, interval range: [0, 4]
|
|
000015:[a#9,1-g#10,1]
|
|
0.1: file count: 1, bytes: 256, width (mean, max): 1.0, 1, interval range: [0, 0]
|
|
000006:[a#7,1-b#8,1]
|
|
0.0: file count: 1, bytes: 256, width (mean, max): 3.0, 3, interval range: [0, 2]
|
|
000004:[a#2,1-e#3,1]
|
|
compacting file count: 0, base compacting intervals: none
|
|
L0.3: d------f
|
|
L0.2: a------------------g
|
|
L0.1: a---b
|
|
L0.0: a------------e
|
|
aa bb cc dd ee ff gg
|
|
|
|
# Exclude the d-f file through earliest_unflushed_seqnum.
|
|
|
|
pick-intra-l0-compaction min_depth=2 earliest_unflushed_seqnum=11
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000015,000006,000004
|
|
seed interval: a-b
|
|
L0.3: d------f
|
|
L0.2: a++++++++++++++++++g
|
|
L0.1: a+++b
|
|
L0.0: a++++++++++++e
|
|
aa bb cc dd ee ff gg
|
|
|
|
pick-intra-l0-compaction min_depth=2
|
|
----
|
|
compaction picked with stack depth reduction 3
|
|
000015,000007,000006,000004
|
|
seed interval: a-b
|
|
L0.3: d++++++f
|
|
L0.2: a++++++++++++++++++g
|
|
L0.1: a+++b
|
|
L0.0: a++++++++++++e
|
|
aa bb cc dd ee ff gg
|