public interface RPermitExpirableSemaphoreRx extends RExpirableRx
Each permit identified by own id and could be released only using its id. Permit id is a 128-bits unique random identifier generated each time during acquiring.
Works in non-fair mode. Therefore order of acquiring is unpredictable.
Modifier and Type | Method and Description |
---|---|
io.reactivex.rxjava3.core.Single<String> |
acquire()
Acquires a permit from this semaphore, blocking until one is
available, or the thread is interrupted.
|
io.reactivex.rxjava3.core.Single<String> |
acquire(long leaseTime,
TimeUnit unit)
Acquires a permit with defined lease time from this semaphore,
blocking until one is available,
or the thread is interrupted.
|
io.reactivex.rxjava3.core.Completable |
addPermits(int permits)
Increases or decreases the number of available permits by defined value.
|
io.reactivex.rxjava3.core.Single<Integer> |
availablePermits()
Returns the current number of available permits.
|
io.reactivex.rxjava3.core.Completable |
release(String permitId)
Releases a permit by its id, returning it to the semaphore.
|
io.reactivex.rxjava3.core.Maybe<String> |
tryAcquire()
Acquires a permit only if one is available at the
time of invocation.
|
io.reactivex.rxjava3.core.Maybe<String> |
tryAcquire(long waitTime,
long leaseTime,
TimeUnit unit)
Acquires a permit with defined lease time from this semaphore,
if one becomes available
within the given waiting time and the current thread has not
been interrupted.
|
io.reactivex.rxjava3.core.Maybe<String> |
tryAcquire(long waitTime,
TimeUnit unit)
Acquires a permit from this semaphore, if one becomes available
within the given waiting time and the current thread has not
been interrupted.
|
io.reactivex.rxjava3.core.Single<Boolean> |
tryRelease(String permitId)
Releases a permit by its id, returning it to the semaphore.
|
io.reactivex.rxjava3.core.Single<Boolean> |
trySetPermits(int permits)
Sets number of permits.
|
io.reactivex.rxjava3.core.Single<Boolean> |
updateLeaseTime(String permitId,
long leaseTime,
TimeUnit unit)
Overrides and updates lease time for defined permit id.
|
clearExpire, expire, expireAt, expireAt, expireAt, remainTimeToLive
addListener, copy, delete, dump, getCodec, getIdleTime, getName, isExists, migrate, move, removeListener, rename, renamenx, restore, restore, restoreAndReplace, restoreAndReplace, sizeInMemory, touch, unlink
io.reactivex.rxjava3.core.Single<String> acquire()
Acquires a permit, if one is available and returns its id, reducing the number of available permits by one.
If no permit is available then the current thread becomes disabled for thread scheduling purposes and lies dormant until one of two things happens:
release(String)
method for this
semaphore and the current thread is next to be assigned a permit; or
io.reactivex.rxjava3.core.Single<String> acquire(long leaseTime, TimeUnit unit)
Acquires a permit, if one is available and returns its id, reducing the number of available permits by one.
If no permit is available then the current thread becomes disabled for thread scheduling purposes and lies dormant until one of two things happens:
release(java.lang.String)
method for this
semaphore and the current thread is next to be assigned a permit; or
leaseTime
- - permit lease timeunit
- - time unitio.reactivex.rxjava3.core.Maybe<String> tryAcquire()
Acquires a permit, if one is available and returns immediately, with the permit id, reducing the number of available permits by one.
If no permit is available then this method will return
immediately with the value null
.
null
otherwiseio.reactivex.rxjava3.core.Maybe<String> tryAcquire(long waitTime, TimeUnit unit)
Acquires a permit, if one is available and returns immediately, with the permit id, reducing the number of available permits by one.
If no permit is available then the current thread becomes disabled for thread scheduling purposes and lies dormant until one of three things happens:
release(String)
method for this
semaphore and the current thread is next to be assigned a permit; or
If a permit is acquired then the permit id is returned.
If the specified waiting time elapses then the value null
is returned. If the time is less than or equal to zero, the method
will not wait at all.
waitTime
- the maximum time to wait for a permitunit
- the time unit of the timeout
argumentnull
if the waiting time elapsed before a permit was acquiredio.reactivex.rxjava3.core.Maybe<String> tryAcquire(long waitTime, long leaseTime, TimeUnit unit)
Acquires a permit, if one is available and returns immediately, with the permit id, reducing the number of available permits by one.
If no permit is available then the current thread becomes disabled for thread scheduling purposes and lies dormant until one of three things happens:
release(String)
method for this
semaphore and the current thread is next to be assigned a permit; or
If a permit is acquired then the permit id is returned.
If the specified waiting time elapses then the value null
is returned. If the time is less than or equal to zero, the method
will not wait at all.
waitTime
- the maximum time to wait for a permitleaseTime
- permit lease timeunit
- the time unit of the timeout
argumentnull
if the waiting time elapsed before a permit was acquiredio.reactivex.rxjava3.core.Single<Boolean> tryRelease(String permitId)
Releases a permit, increasing the number of available permits by one. If any threads of Redisson client are trying to acquire a permit, then one is selected and given the permit that was just released.
There is no requirement that a thread that releases a permit must
have acquired that permit by calling acquire()
.
Correct usage of a semaphore is established by programming convention
in the application.
permitId
- - permit idtrue
if a permit has been released and false
otherwiseio.reactivex.rxjava3.core.Completable release(String permitId)
Releases a permit, increasing the number of available permits by one. If any threads of Redisson client are trying to acquire a permit, then one is selected and given the permit that was just released.
There is no requirement that a thread that releases a permit must
have acquired that permit by calling acquire()
.
Correct usage of a semaphore is established by programming convention
in the application.
Throws an exception if permit id doesn't exist or has already been release
permitId
- - permit idio.reactivex.rxjava3.core.Single<Integer> availablePermits()
io.reactivex.rxjava3.core.Single<Boolean> trySetPermits(int permits)
permits
- - number of permitstrue
if permits has been set successfully, otherwise false
.io.reactivex.rxjava3.core.Completable addPermits(int permits)
permits
- - number of permits to add/removeio.reactivex.rxjava3.core.Single<Boolean> updateLeaseTime(String permitId, long leaseTime, TimeUnit unit)
permitId
- - permit idleaseTime
- - permit lease time, use -1 to make it permanentunit
- - the time unit of the timeout
argumenttrue
if permits has been updated successfully, otherwise false
.Copyright © 2014–2021 Redisson. All rights reserved.