2020-04-11 11:48:32 +02:00
|
|
|
// Package sync is an interface for distributed synchronization
|
2019-05-31 01:43:23 +02:00
|
|
|
package sync
|
|
|
|
|
|
|
|
import (
|
2022-08-11 07:09:25 +02:00
|
|
|
"context"
|
2022-02-24 11:07:14 +02:00
|
|
|
"crypto/tls"
|
2020-04-11 11:37:54 +02:00
|
|
|
"errors"
|
|
|
|
"time"
|
2022-09-29 16:44:53 +02:00
|
|
|
|
2024-06-04 22:40:43 +02:00
|
|
|
"go-micro.dev/v5/logger"
|
2019-05-31 01:43:23 +02:00
|
|
|
)
|
|
|
|
|
2020-04-11 11:37:54 +02:00
|
|
|
var (
|
|
|
|
ErrLockTimeout = errors.New("lock timeout")
|
|
|
|
)
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// Sync is an interface for distributed synchronization.
|
2020-04-11 11:37:54 +02:00
|
|
|
type Sync interface {
|
2022-09-30 16:27:07 +02:00
|
|
|
// Initialize options
|
2020-04-11 11:37:54 +02:00
|
|
|
Init(...Option) error
|
|
|
|
// Return the options
|
|
|
|
Options() Options
|
|
|
|
// Elect a leader
|
|
|
|
Leader(id string, opts ...LeaderOption) (Leader, error)
|
|
|
|
// Lock acquires a lock
|
|
|
|
Lock(id string, opts ...LockOption) error
|
|
|
|
// Unlock releases a lock
|
|
|
|
Unlock(id string) error
|
|
|
|
// Sync implementation
|
|
|
|
String() string
|
2019-05-31 01:43:23 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// Leader provides leadership election.
|
2020-04-11 11:37:54 +02:00
|
|
|
type Leader interface {
|
2020-04-12 12:16:08 +02:00
|
|
|
// resign leadership
|
|
|
|
Resign() error
|
|
|
|
// status returns when leadership is lost
|
|
|
|
Status() chan bool
|
2019-05-31 01:43:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type Options struct {
|
2022-08-11 07:09:25 +02:00
|
|
|
Context context.Context
|
2022-09-29 16:44:53 +02:00
|
|
|
Logger logger.Logger
|
2023-04-26 02:16:34 +02:00
|
|
|
TLSConfig *tls.Config
|
|
|
|
Prefix string
|
|
|
|
Nodes []string
|
2019-05-31 01:43:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type Option func(o *Options)
|
2020-04-11 11:37:54 +02:00
|
|
|
|
2020-04-12 12:16:08 +02:00
|
|
|
type LeaderOptions struct{}
|
2020-04-11 11:37:54 +02:00
|
|
|
|
|
|
|
type LeaderOption func(o *LeaderOptions)
|
|
|
|
|
|
|
|
type LockOptions struct {
|
|
|
|
TTL time.Duration
|
|
|
|
Wait time.Duration
|
|
|
|
}
|
|
|
|
|
|
|
|
type LockOption func(o *LockOptions)
|