summaryrefslogtreecommitdiff
path: root/meta/3rd/OpenResty/library/resty/lock.lua
blob: e5543597b8692df4860ed3c2d66fc8ddc327535c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
---@meta

--- lua-resty-lock
---
--- https://github.com/openresty/lua-resty-lock
---
---@class resty.lock : table
local lock = {
  _VERSION = "0.08",
}


---@class resty.lock.opts : table
---
--- Specifies expiration time (in seconds) for the lock entry in the shared memory
--- dictionary. You can specify up to 0.001 seconds. Default to 30 (seconds). Even
--- if the invoker does not call unlock or the object holding the lock is not GC'd,
--- the lock will be released after this time. So deadlock won't happen even when the
--- worker process holding the lock crashes.
---@field exptime  number
---
--- Specifies the maximal waiting time (in seconds) for the lock method calls on
--- the current object instance. You can specify up to 0.001 seconds. Default to 5
--- (seconds). This option value cannot be bigger than `exptime`. This timeout is
--- to prevent a lock method call from waiting forever. You can specify 0 to make
--- the lock method return immediately without waiting if it cannot acquire the
--- lock right away.
---@field timeout  number
---
--- Specifies the initial step (in seconds) of sleeping when waiting for the lock.
--- Default to 0.001 (seconds). When the lock method is waiting on a busy lock, it
--- sleeps by steps. The step size is increased by a ratio (specified by the ratio
--- option) until reaching the step size limit (specified by the max_step option).
---@field step     number
---
--- Specifies the step increasing ratio. Default to 2, that is, the step size
--- doubles at each waiting iteration.
---@field ratio    number
---
--- Specifies the maximal step size (i.e., sleep interval, in seconds) allowed.
--- See also the step and ratio options). Default to 0.5 (seconds).
---@field max_step number


--- Creates a new lock object instance by specifying the shared dictionary name
--- (created by `lua_shared_dict`) and an optional options table `opts`.
---
---@param  dict_name   string
---@param  opts?       resty.lock.opts
---@return resty.lock? lock
---@return string?     err
function lock.new(_, dict_name, opts) end

--- Tries to lock a key across all the Nginx worker processes in the current
--- NGINX server instance. Different keys are different locks.
---
--- The length of the key string must not be larger than 65535 bytes.
---
--- Returns the waiting time (in seconds) if the lock is successfully acquired.
--- Otherwise returns `nil` and a string describing the error.
---
--- The waiting time is not from the wallclock, but rather is from simply adding
--- up all the waiting "steps". A nonzero elapsed return value indicates that
--- someone else has just hold this lock. But a zero return value cannot gurantee
--- that no one else has just acquired and released the lock.
---
--- When this method is waiting on fetching the lock, no operating system threads
--- will be blocked and the current Lua "light thread" will be automatically yielded
--- behind the scene.
---
--- It is strongly recommended to always call the unlock() method to actively
--- release the lock as soon as possible.
---
--- If the `unlock()` method is never called after this method call, the lock
--- will get released when
---
---   The current `resty.lock` object instance is collected automatically by the Lua GC.
---   OR
---   The exptime for the lock entry is reached.
---
--- Common errors for this method call is
---
---   "timeout" : The timeout threshold specified by the timeout option of the new method is exceeded.
---   "locked" : The current `resty.lock` object instance is already holding a lock (not necessarily of the same key).
---
--- Other possible errors are from ngx_lua's shared dictionary API.
---
--- It is required to create different `resty.lock` instances for multiple
--- simultaneous locks (i.e., those around different keys).
---
---@param  key     string
---@return number? elapsed
---@return string? error
function lock:lock(key) end

--- Releases the lock held by the current `resty.lock` object instance.
---
--- Returns 1 on success. Returns `nil` and a string describing the error otherwise.
---
--- If you call unlock when no lock is currently held, the error "unlocked" will
--- be returned.
---
---@return boolean ok
---@return string? error
function lock:unlock() end

--- Sets the TTL of the lock held by the current `resty.lock` object instance.
--- This will reset the timeout of the lock to timeout seconds if it is given,
--- otherwise the timeout provided while calling new will be used.
---
--- Note that the timeout supplied inside this function is independent from the
--- timeout provided while calling new. Calling `expire()` will not change the
--- timeout value specified inside new and subsequent `expire(nil)` call will
--- still use the timeout number from new.
---
--- Returns true on success. Returns `nil` and a string describing the error
--- otherwise.
---
--- If you call expire when no lock is currently held, the error "unlocked" will
--- be returned.
---
---@param  timeout? number
---@return boolean  ok
---@return string?  error
function lock:expire(timeout) end

return lock