mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-11 05:47:27 -08:00
Add WALSegmentSize as an option of tsdb creation (#450)
Expose `WALSegmentSize` option to allow overriding the `DefaultOptions.WALSegmentSize`.
This commit is contained in:
parent
520ab7dc53
commit
22e3aeb107
|
@ -1,11 +1,10 @@
|
||||||
## master / unreleased
|
## master / unreleased
|
||||||
|
- [CHANGE] New `WALSegmentSize` option to override the `DefaultOptions.WALSegmentSize`. Added to allow using smaller wal files. For example using tmpfs on a RPI to minimise the SD card wear out from the constant WAL writes. As part of this change the `DefaultOptions.WALSegmentSize` constant was also exposed.
|
||||||
|
|
||||||
## 0.3.1
|
## 0.3.1
|
||||||
- [BUGFIX] Fixed most windows test and some actual bugs for unclosed file readers.
|
- [BUGFIX] Fixed most windows test and some actual bugs for unclosed file readers.
|
||||||
|
|
||||||
## 0.3.0
|
## 0.3.0
|
||||||
|
|
||||||
- [CHANGE] `LastCheckpoint()` used to return just the segment name and now it returns the full relative path.
|
- [CHANGE] `LastCheckpoint()` used to return just the segment name and now it returns the full relative path.
|
||||||
- [CHANGE] `NewSegmentsRangeReader()` can now read over miltiple wal ranges by using the new `SegmentRange{}` struct.
|
- [CHANGE] `NewSegmentsRangeReader()` can now read over miltiple wal ranges by using the new `SegmentRange{}` struct.
|
||||||
- [CHANGE] `CorruptionErr{}` now also exposes the Segment `Dir` which is added when displaying any errors.
|
- [CHANGE] `CorruptionErr{}` now also exposes the Segment `Dir` which is added when displaying any errors.
|
||||||
|
|
10
db.go
10
db.go
|
@ -45,6 +45,7 @@ import (
|
||||||
// millisecond precision timestamps.
|
// millisecond precision timestamps.
|
||||||
var DefaultOptions = &Options{
|
var DefaultOptions = &Options{
|
||||||
WALFlushInterval: 5 * time.Second,
|
WALFlushInterval: 5 * time.Second,
|
||||||
|
WALSegmentSize: wal.DefaultSegmentSize,
|
||||||
RetentionDuration: 15 * 24 * 60 * 60 * 1000, // 15 days in milliseconds
|
RetentionDuration: 15 * 24 * 60 * 60 * 1000, // 15 days in milliseconds
|
||||||
BlockRanges: ExponentialBlockRanges(int64(2*time.Hour)/1e6, 3, 5),
|
BlockRanges: ExponentialBlockRanges(int64(2*time.Hour)/1e6, 3, 5),
|
||||||
NoLockfile: false,
|
NoLockfile: false,
|
||||||
|
@ -55,6 +56,9 @@ type Options struct {
|
||||||
// The interval at which the write ahead log is flushed to disk.
|
// The interval at which the write ahead log is flushed to disk.
|
||||||
WALFlushInterval time.Duration
|
WALFlushInterval time.Duration
|
||||||
|
|
||||||
|
// Segments (wal files) max size
|
||||||
|
WALSegmentSize int
|
||||||
|
|
||||||
// Duration of persisted data to keep.
|
// Duration of persisted data to keep.
|
||||||
RetentionDuration uint64
|
RetentionDuration uint64
|
||||||
|
|
||||||
|
@ -263,7 +267,11 @@ func Open(dir string, l log.Logger, r prometheus.Registerer, opts *Options) (db
|
||||||
return nil, errors.Wrap(err, "create leveled compactor")
|
return nil, errors.Wrap(err, "create leveled compactor")
|
||||||
}
|
}
|
||||||
|
|
||||||
wlog, err := wal.New(l, r, filepath.Join(dir, "wal"))
|
segmentSize := wal.DefaultSegmentSize
|
||||||
|
if opts.WALSegmentSize > 0 {
|
||||||
|
segmentSize = opts.WALSegmentSize
|
||||||
|
}
|
||||||
|
wlog, err := wal.NewSize(l, r, filepath.Join(dir, "wal"), segmentSize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
24
db_test.go
24
db_test.go
|
@ -695,6 +695,30 @@ func TestWALFlushedOnDBClose(t *testing.T) {
|
||||||
testutil.Equals(t, []string{"labelvalue"}, values)
|
testutil.Equals(t, []string{"labelvalue"}, values)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestWALSegmentSizeOption(t *testing.T) {
|
||||||
|
options := *DefaultOptions
|
||||||
|
options.WALSegmentSize = 2 * 32 * 1024
|
||||||
|
db, close := openTestDB(t, &options)
|
||||||
|
defer close()
|
||||||
|
app := db.Appender()
|
||||||
|
for i := int64(0); i < 155; i++ {
|
||||||
|
_, err := app.Add(labels.Labels{labels.Label{Name: "wal", Value: "size"}}, i, rand.Float64())
|
||||||
|
testutil.Ok(t, err)
|
||||||
|
testutil.Ok(t, app.Commit())
|
||||||
|
}
|
||||||
|
|
||||||
|
files, err := ioutil.ReadDir(filepath.Join(db.Dir(), "wal"))
|
||||||
|
testutil.Assert(t, len(files) > 1, "current WALSegmentSize should result in more than a single WAL file.")
|
||||||
|
testutil.Ok(t, err)
|
||||||
|
for i, f := range files {
|
||||||
|
if len(files)-1 != i {
|
||||||
|
testutil.Equals(t, int64(options.WALSegmentSize), f.Size(), "WAL file size doesn't match WALSegmentSize option, filename: %v", f.Name())
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
testutil.Assert(t, int64(options.WALSegmentSize) > f.Size(), "last WAL file size is not smaller than the WALSegmentSize option, filename: %v", f.Name())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestTombstoneClean(t *testing.T) {
|
func TestTombstoneClean(t *testing.T) {
|
||||||
numSamples := int64(10)
|
numSamples := int64(10)
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
defaultSegmentSize = 128 * 1024 * 1024 // 128 MB
|
DefaultSegmentSize = 128 * 1024 * 1024 // 128 MB
|
||||||
pageSize = 32 * 1024 // 32KB
|
pageSize = 32 * 1024 // 32KB
|
||||||
recordHeaderSize = 7
|
recordHeaderSize = 7
|
||||||
)
|
)
|
||||||
|
@ -174,7 +174,7 @@ type WAL struct {
|
||||||
|
|
||||||
// New returns a new WAL over the given directory.
|
// New returns a new WAL over the given directory.
|
||||||
func New(logger log.Logger, reg prometheus.Registerer, dir string) (*WAL, error) {
|
func New(logger log.Logger, reg prometheus.Registerer, dir string) (*WAL, error) {
|
||||||
return NewSize(logger, reg, dir, defaultSegmentSize)
|
return NewSize(logger, reg, dir, DefaultSegmentSize)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewSize returns a new WAL over the given directory.
|
// NewSize returns a new WAL over the given directory.
|
||||||
|
|
Loading…
Reference in a new issue