Documentation ¶
Index ¶
- Constants
- Variables
- func NewDefaultLockFactory() *build.Factory
- type ILock
- type ILockOverrides
- type Lock
- type MemoryLock
- type NullLock
- func (c *NullLock) AcquireLock(ctx context.Context, correlationId string, key string, ttl int, timeout int) error
- func (c *NullLock) ReleaseLock(ctx context.Context, correlationId string, key string) error
- func (c *NullLock) TryAcquireLock(ctx context.Context, correlationId string, key string, ttl int) (bool, error)
Constants ¶
const ( DefaultRetryTimeout int64 = 100 ConfigParamOptionsRetryTimeout string = "options.retry_timeout" )
Variables ¶
var MemoryLockDescriptor = refer.NewDescriptor("pip-services", "lock", "memory", "*", "1.0")
var NullLockDescriptor = refer.NewDescriptor("pip-services", "lock", "null", "*", "1.0")
Functions ¶
func NewDefaultLockFactory ¶
NewDefaultLockFactory create a new instance of the factory.
Returns: *build.Factory
Types ¶
type ILock ¶
type ILock interface { // TryAcquireLock Makes a single attempt to acquire a lock by its key. // It returns immediately a positive or negative result. TryAcquireLock(ctx context.Context, correlationId string, key string, ttl int64) (bool, error) // AcquireLock makes multiple attempts to acquire a lock by its key within // give time interval. AcquireLock(ctx context.Context, correlationId string, key string, ttl int64, timeout int64) error // ReleaseLock releases previously acquired lock by its key. ReleaseLock(ctx context.Context, correlationId string, key string) error }
ILock Interface for locks to synchronize work or parallel processes and to prevent collisions. The lock allows managing multiple locks identified by unique keys.
type ILockOverrides ¶ added in v1.0.4
type ILockOverrides interface { ILock }
type Lock ¶
type Lock struct { Overrides ILockOverrides // contains filtered or unexported fields }
Lock abstract lock that implements default lock acquisition routine.
Configuration parameters: options: retry_timeout: timeout in milliseconds to retry lock acquisition. (Default: 100)
func InheritLock ¶
func InheritLock(overrides ILockOverrides) *Lock
InheritLock inherit lock from ILockOverrides
Returns: *Lock
func (*Lock) AcquireLock ¶
func (c *Lock) AcquireLock(ctx context.Context, correlationId string, key string, ttl int64, timeout int64) error
AcquireLock makes multiple attempts to acquire a lock by its key within give time interval.
Parameters: - ctx context.Context - correlationId string transaction id to trace execution through call chain. - key string a unique lock key to acquire. - ttl int64 a lock timeout (time to live) in milliseconds. - timeout int64 a lock acquisition timeout.
Returns error
type MemoryLock ¶
type MemoryLock struct { Lock // contains filtered or unexported fields }
MemoryLock Lock that is used to synchronize execution within one process using shared memory.
Configuration parameters: options: retry_timeout: timeout in milliseconds to retry lock acquisition. (Default: 100) see ILock see Lock Example: lock := NewMemoryLock() err = lock.Acquire("123", "key1") if err == nil { _ = lock.ReleaseLock("123", "key1") // Processing... }
func NewMemoryLock ¶
func NewMemoryLock() *MemoryLock
NewMemoryLock create new memory lock
Returns: *MemoryLock
func (*MemoryLock) ReleaseLock ¶
ReleaseLock releases the lock with the given key.
Parameters: - ctx context.Context - correlationId string not used. - key string the key of the lock that is to be released. Return: error
func (*MemoryLock) TryAcquireLock ¶
func (c *MemoryLock) TryAcquireLock(ctx context.Context, correlationId string, key string, ttl int64) (bool, error)
TryAcquireLock makes a single attempt to acquire a lock by its key. It returns immediately a positive or negative result.
Parameters: - ctx context.Context - correlationId string transaction id to trace execution through call chain. - key string a unique lock key to acquire. - ttl int64 a lock timeout (time to live) in milliseconds. Returns bool, error true if locked. Error object
type NullLock ¶
type NullLock struct{}
NullLock Dummy lock implementation that doesn't do anything. It can be used in testing or in situations when lock is required but shall be disabled.
func NewNullLock ¶
func NewNullLock() *NullLock
func (*NullLock) AcquireLock ¶
func (c *NullLock) AcquireLock(ctx context.Context, correlationId string, key string, ttl int, timeout int) error
AcquireLock makes multiple attempts to acquire a lock by its key within give time interval.
Parameters: - ctx context.Context - correlationId string transaction id to trace execution through call chain. - key string a unique lock key to acquire. - ttl int64 a lock timeout (time to live) in milliseconds. - timeout int64 a lock acquisition timeout. Returns: error
func (*NullLock) ReleaseLock ¶
ReleaseLock releases the lock with the given key.
Parameters: - ctx context.Context - correlationId string not used. - key string the key of the lock that is to be released. Return: error
func (*NullLock) TryAcquireLock ¶
func (c *NullLock) TryAcquireLock(ctx context.Context, correlationId string, key string, ttl int) (bool, error)
TryAcquireLock makes a single attempt to acquire a lock by its key. It returns immediately a positive or negative result.
Parameters: - ctx context.Context - correlationId string transaction id to trace execution through call chain. - key string a unique lock key to acquire. - ttl int64 a lock timeout (time to live) in milliseconds. Returns bool, error true if locked. Error object