locker

package
v0.3.10 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 8, 2023 License: MIT Imports: 9 Imported by: 0

Documentation

Index

Constants

View Source
const UNLOCK_SCRIPT = `
	if redis.call("GET", KEYS[1]) == ARGV[1] then
		return redis.call("DEL", KEYS[1])
	else
		return 0
	end
`

UNLOCK_SCRIPT 释放锁脚本

Variables

View Source
var (
	ErrInvalidRedisAdapterParams = errors.New("无效的redis适配器参数")
	ErrInvalidDefaultName        = errors.New("无效的默认实例")

	ErrAdapterNotFound      = errors.New("找不到适配器")
	ErrAdapterUninitialized = errors.New("适配器未初始化")

	ErrTimeout = errors.New("获取锁超时")
)

Functions

func Init

func Init(conf []Config, defaultAdapter string) error

Init 初始化设置,在框架初始化时调用

func LockFunc

func LockFunc(resource string, ttl uint64, fn func() interface{}) (interface{}, error)

LockFunc 启用分布式锁执行fn resource 资源标识,相同的资源标识会互斥 ttl 生存时间 (秒) f 返回interface{} 的函数 在获取锁失败或超时的情况下,fn不会被执行

Types

type Config added in v0.2.23

type Config struct {
	Name    string            `json:"name" toml:"name"`
	Adapter string            `json:"adapter" toml:"adapter"`
	Option  map[string]string `json:"option" toml:"option"`
}

type Locker

type Locker interface {

	// Lock 分布式自旋锁
	// resource 资源标识,相同的资源标识会互斥
	// ttl 生存时间 (秒)
	Lock(resource string, ttl uint64) (Releaser, error)

	// TryLock 尝试获取锁
	// resource 资源标识,相同的资源标识会互斥
	// ttl 生存时间 (秒)
	TryLock(resource string, ttl uint64) (Releaser, bool, error)

	// LockFunc 分布式自旋锁执行fn
	// resource 资源标识,相同的资源标识会互斥
	// ttl 生存时间 (秒)
	// f 返回interface{} 的函数
	// 在获取锁失败或超时的情况下,fn不会被执行
	LockFunc(resource string, ttl uint64, fn func() interface{}) (interface{}, error)
}

func Instance added in v0.2.23

func Instance(name string) (Locker, error)

Instance 获取分布式锁实例

type Manager added in v0.2.23

type Manager struct {
	sync.Map
	// contains filtered or unexported fields
}

type Releaser added in v0.2.23

type Releaser interface {
	Release() error
}

func Lock added in v0.2.23

func Lock(resource string, ttl uint64) (Releaser, error)

Lock 分布式自旋锁

func TryLock

func TryLock(resource string, ttl uint64) (Releaser, bool, error)

TryLock 尝试获取锁 resource 资源标识,相同的资源标识会互斥 ttl 生存时间 (秒)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL