ConcurrencyLimiter
class ConcurrencyLimiter (View source)
Properties
| protected Connection | $redis | The Redis factory implementation. | |
| protected string | $name | The name of the limiter. | |
| protected int | $maxLocks | The allowed number of concurrent tasks. | |
| protected int | $releaseAfter | The number of seconds a slot should be maintained. | 
Methods
Create a new concurrency limiter instance.
Attempt to acquire the lock for the given number of seconds.
Attempt to acquire the lock.
Get the Lua script for acquiring a lock.
Release the lock.
Get the Lua script to atomically release a lock.
Details
        
                            
    __construct(Connection $redis, string $name, int $maxLocks, int $releaseAfter)
        
    
    Create a new concurrency limiter instance.
        
                            mixed
    block(int $timeout, callable|null $callback = null, int $sleep = 250)
        
    
    Attempt to acquire the lock for the given number of seconds.
        
                    protected        mixed
    acquire(string $id)
        
    
    Attempt to acquire the lock.
        
                    protected        string
    lockScript()
        
    
    Get the Lua script for acquiring a lock.
KEYS - The keys that represent available slots ARGV[1] - The limiter name ARGV[2] - The number of seconds the slot should be reserved ARGV[3] - The unique identifier for this lock
        
                    protected        void
    release(string $key, string $id)
        
    
    Release the lock.
        
                    protected        string
    releaseScript()
        
    
    Get the Lua script to atomically release a lock.
KEYS[1] - The name of the lock ARGV[1] - The unique identifier for this lock