mirror of
https://github.com/prometheus/prometheus.git
synced 2024-12-26 22:19:40 -08:00
baca6faa1c
This mimics the locking leveldb is performing anyway. Advantages of doing it separately: - Should we ever replace the leveldb implementation by one without double-start protection, we are still good. - In contrast to leveldb, the new code creates a meaningful error message.
42 lines
673 B
Go
42 lines
673 B
Go
// +build darwin dragonfly freebsd linux netbsd openbsd
|
|
|
|
package flock
|
|
|
|
import (
|
|
"os"
|
|
"syscall"
|
|
)
|
|
|
|
type unixLock struct {
|
|
f *os.File
|
|
}
|
|
|
|
func (l *unixLock) Release() error {
|
|
if err := l.set(false); err != nil {
|
|
return err
|
|
}
|
|
return l.f.Close()
|
|
}
|
|
|
|
func (l *unixLock) set(lock bool) error {
|
|
how := syscall.LOCK_UN
|
|
if lock {
|
|
how = syscall.LOCK_EX
|
|
}
|
|
return syscall.Flock(int(l.f.Fd()), how|syscall.LOCK_NB)
|
|
}
|
|
|
|
func newLock(fileName string) (Releaser, error) {
|
|
f, err := os.OpenFile(fileName, os.O_RDWR|os.O_CREATE, 0644)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
l := &unixLock{f}
|
|
err = l.set(true)
|
|
if err != nil {
|
|
f.Close()
|
|
return nil, err
|
|
}
|
|
return l, nil
|
|
}
|