remove Fsync workaround for macos. (#574)

since golang 1.12 no special handling is required for file.Sync()

@pborzenkov thanks for the pointer.

Signed-off-by: Krasi Georgiev <kgeorgie@redhat.com>
This commit is contained in:
Krasi Georgiev 2019-04-03 11:16:54 +03:00 committed by GitHub
parent 4f204dcbc1
commit 8eeb70fee1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
15 changed files with 75 additions and 36 deletions

View file

@ -6,8 +6,6 @@ os:
- osx
go:
- 1.10.x
- 1.11.x
- 1.12.x
go_import_path: github.com/prometheus/tsdb

View file

@ -1,4 +1,5 @@
## master / unreleased
- [CHANGE] tsdb now requires golang 1.12 or higher.
- [REMOVED] `chunks.NewReader` is removed as it wasn't used anywhere.
- [REMOVED] `FromData` is considered unused so was removed.
- [FEATURE] Added option WALSegmentSize -1 to disable the WAL.

View file

@ -139,7 +139,7 @@ func (w *Writer) finalizeTail() error {
if err := w.wbuf.Flush(); err != nil {
return err
}
if err := fileutil.Fsync(tf); err != nil {
if err := tf.Sync(); err != nil {
return err
}
// As the file was pre-allocated, we truncate any superfluous zero bytes.

View file

@ -626,7 +626,7 @@ func (c *LeveledCompactor) write(dest string, meta *BlockMeta, blocks ...BlockRe
}
}()
if err := fileutil.Fsync(df); err != nil {
if err := df.Sync(); err != nil {
return errors.Wrap(err, "sync temporary dir file")
}
@ -1026,7 +1026,7 @@ func renameFile(from, to string) error {
return err
}
if err = fileutil.Fsync(pdir); err != nil {
if err = pdir.Sync(); err != nil {
pdir.Close()
return err
}

1
db.go
View file

@ -37,6 +37,7 @@ import (
"github.com/prometheus/tsdb/chunkenc"
tsdb_errors "github.com/prometheus/tsdb/errors"
"github.com/prometheus/tsdb/fileutil"
_ "github.com/prometheus/tsdb/goversion"
"github.com/prometheus/tsdb/labels"
"github.com/prometheus/tsdb/wal"
"golang.org/x/sync/errgroup"

View file

@ -118,7 +118,7 @@ func Rename(from, to string) error {
return err
}
if err = Fsync(pdir); err != nil {
if err = pdir.Sync(); err != nil {
pdir.Close()
return err
}
@ -141,7 +141,7 @@ func Replace(from, to string) error {
return err
}
if err = Fsync(pdir); err != nil {
if err = pdir.Sync(); err != nil {
pdir.Close()
return err
}

View file

@ -18,11 +18,6 @@ package fileutil
import "os"
// Fsync is a wrapper around file.Sync(). Special handling is needed on darwin platform.
func Fsync(f *os.File) error {
return f.Sync()
}
// Fdatasync is a wrapper around file.Sync(). Special handling is needed on linux platform.
func Fdatasync(f *os.File) error {
return f.Sync()

View file

@ -18,23 +18,10 @@ package fileutil
import (
"os"
"syscall"
)
// Fsync on HFS/OSX flushes the data on to the physical drive but the drive
// may not write it to the persistent media for quite sometime and it may be
// written in out-of-order sequence. Using F_FULLFSYNC ensures that the
// physical drive's buffer will also get flushed to the media.
func Fsync(f *os.File) error {
_, _, errno := syscall.Syscall(syscall.SYS_FCNTL, f.Fd(), uintptr(syscall.F_FULLFSYNC), uintptr(0))
if errno == 0 {
return nil
}
return errno
}
// Fdatasync on darwin platform invokes fcntl(F_FULLFSYNC) for actual persistence
// on physical drive media.
func Fdatasync(f *os.File) error {
return Fsync(f)
return f.Sync()
}

View file

@ -21,11 +21,6 @@ import (
"syscall"
)
// Fsync is a wrapper around file.Sync(). Special handling is needed on darwin platform.
func Fsync(f *os.File) error {
return f.Sync()
}
// Fdatasync is similar to fsync(), but does not flush modified metadata
// unless that metadata is needed in order to allow a subsequent data retrieval
// to be correctly handled.

View file

@ -0,0 +1,27 @@
// Copyright 2017 The Prometheus Authors
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package goversion_test
import (
"testing"
_ "github.com/prometheus/tsdb/goversion"
)
// This test is is intentionally blank and exists only so `go test` believes
// there is something to test.
//
// The blank import above is actually what invokes the test of this package. If
// the import succeeds (the code compiles), the test passed.
func Test(t *testing.T) {}

19
goversion/goversion.go Normal file
View file

@ -0,0 +1,19 @@
// Copyright 2017 The Prometheus Authors
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// +build go1.12
// Package goversion enforces the go version suported by the tsdb module.
package goversion
const _SoftwareRequiresGOVERSION1_12 = uint8(0)

17
goversion/init.go Normal file
View file

@ -0,0 +1,17 @@
// Copyright 2017 The Prometheus Authors
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package goversion
// This will fail to compile if the Go runtime version isn't >= 1.12.
var _ = _SoftwareRequiresGOVERSION1_12

View file

@ -192,7 +192,7 @@ func NewWriter(fn string) (*Writer, error) {
if err != nil {
return nil, err
}
if err := fileutil.Fsync(df); err != nil {
if err := df.Sync(); err != nil {
return nil, errors.Wrap(err, "sync dir")
}
@ -554,7 +554,7 @@ func (w *Writer) Close() error {
if err := w.fbuf.Flush(); err != nil {
return err
}
if err := fileutil.Fsync(w.f); err != nil {
if err := w.f.Sync(); err != nil {
return err
}
return w.f.Close()

View file

@ -23,7 +23,6 @@ import (
"github.com/go-kit/kit/log"
"github.com/go-kit/kit/log/level"
"github.com/pkg/errors"
"github.com/prometheus/tsdb/fileutil"
)
// repairBadIndexVersion repairs an issue in index and meta.json persistence introduced in
@ -75,7 +74,7 @@ func repairBadIndexVersion(logger log.Logger, dir string) error {
if _, err := repl.WriteAt([]byte{2}, 4); err != nil {
return wrapErr(err, d)
}
if err := fileutil.Fsync(repl); err != nil {
if err := repl.Sync(); err != nil {
return wrapErr(err, d)
}
if err := repl.Close(); err != nil {

View file

@ -595,7 +595,7 @@ func (w *WAL) Truncate(i int) (err error) {
func (w *WAL) fsync(f *Segment) error {
start := time.Now()
err := fileutil.Fsync(f.File)
err := f.File.Sync()
w.fsyncDuration.Observe(time.Since(start).Seconds())
return err
}