micro/sync/lock/lock.go

28 lines
491 B
Go
Raw Normal View History

2019-05-31 02:43:23 +03:00
// Package lock provides distributed locking
package lock
import (
"time"
)
// Lock is a distributed locking interface
type Lock interface {
// Acquire a lock with given id
Acquire(id string, opts ...AcquireOption) error
// Release the lock with given id
Release(id string) error
}
type Options struct {
Nodes []string
Prefix string
}
type AcquireOptions struct {
TTL time.Duration
Wait time.Duration
}
type Option func(o *Options)
type AcquireOption func(o *AcquireOptions)