Package org.redisson
Class RedissonReliableTopic
- java.lang.Object
-
- org.redisson.RedissonObject
-
- org.redisson.RedissonReliableTopic
-
- All Implemented Interfaces:
RExpirable,RExpirableAsync,RObject,RObjectAsync,RReliableTopic,RReliableTopicAsync
public class RedissonReliableTopic extends RedissonObject implements RReliableTopic
- Author:
- Nikita Koksharov
-
-
Field Summary
-
Fields inherited from class org.redisson.RedissonObject
codec, commandExecutor, name
-
-
Constructor Summary
Constructors Constructor Description RedissonReliableTopic(Codec codec, CommandAsyncExecutor commandExecutor, String name)RedissonReliableTopic(CommandAsyncExecutor commandExecutor, String name)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description <M> StringaddListener(Class<M> type, MessageListener<M> listener)Subscribes to this topic.<M> RFuture<String>addListenerAsync(Class<M> type, MessageListener<M> listener)Subscribes to this topic.booleanclearExpire()Clear an expire timeout or expire date for object.RFuture<Boolean>clearExpireAsync()Clear an expire timeout or expire date for object in async mode.protected RFuture<Boolean>clearExpireAsync(String... keys)intcountListeners()Returns amount of registered listeners to this topicintcountSubscribers()Returns amount of subscribers to this topic across all Redisson instances.RFuture<Integer>countSubscribersAsync()Returns amount of subscribers to this topic across all Redisson instances.RFuture<Boolean>deleteAsync()Delete object in async modebooleanexpire(long timeToLive, TimeUnit timeUnit)Set a timeout for object.booleanexpire(Instant instant)Set an expire date for object.RFuture<Boolean>expireAsync(long timeToLive, TimeUnit timeUnit)Set a timeout for object in async mode.protected RFuture<Boolean>expireAsync(long timeToLive, TimeUnit timeUnit, String... keys)RFuture<Boolean>expireAsync(Instant instant)Set an expire date for object.booleanexpireAt(long timestamp)UseRExpirable.expire(Instant)insteadbooleanexpireAt(Date timestamp)UseRExpirable.expire(Instant)insteadRFuture<Boolean>expireAtAsync(long timestamp)UseRExpirableAsync.expireAsync(Instant)insteadprotected RFuture<Boolean>expireAtAsync(long timestamp, String... keys)RFuture<Boolean>expireAtAsync(Date timestamp)UseRExpirableAsync.expireAsync(Instant)insteadprotected StringgenerateId()longpublish(Object message)Publish the message to all subscribers of this topic asynchronously.RFuture<Long>publishAsync(Object message)Publish the message to all subscribers of this topic asynchronously.longremainTimeToLive()Remaining time to live of Redisson object that has a timeoutRFuture<Long>remainTimeToLiveAsync()Remaining time to live of Redisson object that has a timeoutvoidremoveAllListeners()Removes all listeners from this topicRFuture<Void>removeAllListenersAsync()Removes all listeners from this topicvoidremoveListener(String... listenerIds)Removes the listener byidfor listening this topicRFuture<Void>removeListenerAsync(String... listenerIds)Removes the listener byidfor listening this topiclongsize()Amount of messages stored in Redis Stream object.RFuture<Long>sizeAsync()Amount of messages stored in Redis Stream object.RFuture<Long>sizeInMemoryAsync()Returns bytes amount used by object in Redis memory.-
Methods inherited from class org.redisson.RedissonObject
addListener, addListener, addListenerAsync, addListenerAsync, copy, copyAsync, delete, deleteAsync, dump, dumpAsync, encode, encode, encode, encode, encodeMapKey, encodeMapKeys, encodeMapValue, encodeMapValues, get, getCodec, getIdleTime, getIdleTimeAsync, getLockByMapKey, getLockByValue, getName, getRawName, getRawName, isExists, isExistsAsync, migrate, migrateAsync, move, moveAsync, prefixName, removeListener, removeListenerAsync, removeListenersAsync, rename, renameAsync, renamenx, renamenxAsync, restore, restore, restoreAndReplace, restoreAndReplace, restoreAndReplaceAsync, restoreAndReplaceAsync, restoreAsync, restoreAsync, setName, sizeInMemory, sizeInMemoryAsync, sizeInMemoryAsync, suffixName, toSeconds, toStream, touch, touchAsync, unlink, unlinkAsync
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.redisson.api.RExpirable
clearExpire, expire, expire, expireAt, expireAt, remainTimeToLive
-
Methods inherited from interface org.redisson.api.RExpirableAsync
expireAsync, expireAtAsync, expireAtAsync, remainTimeToLiveAsync
-
Methods inherited from interface org.redisson.api.RObject
addListener, copy, delete, dump, getCodec, getIdleTime, getName, isExists, migrate, move, removeListener, rename, renamenx, restore, restore, restoreAndReplace, restoreAndReplace, sizeInMemory, touch, unlink
-
Methods inherited from interface org.redisson.api.RObjectAsync
addListenerAsync, copyAsync, dumpAsync, getIdleTimeAsync, isExistsAsync, migrateAsync, moveAsync, removeListenerAsync, renameAsync, renamenxAsync, restoreAndReplaceAsync, restoreAndReplaceAsync, restoreAsync, restoreAsync, touchAsync, unlinkAsync
-
-
-
-
Constructor Detail
-
RedissonReliableTopic
public RedissonReliableTopic(Codec codec, CommandAsyncExecutor commandExecutor, String name)
-
RedissonReliableTopic
public RedissonReliableTopic(CommandAsyncExecutor commandExecutor, String name)
-
-
Method Detail
-
publish
public long publish(Object message)
Description copied from interface:RReliableTopicPublish the message to all subscribers of this topic asynchronously. Each subscriber may have multiple listeners.- Specified by:
publishin interfaceRReliableTopic- Parameters:
message- to send- Returns:
- number of subscribers that received the message
-
addListener
public <M> String addListener(Class<M> type, MessageListener<M> listener)
Description copied from interface:RReliableTopicSubscribes to this topic.MessageListener.onMessagemethod is called when any message is published on this topic.Watchdog is started when listener was registered.
- Specified by:
addListenerin interfaceRReliableTopic- Type Parameters:
M- - type of message- Parameters:
type- - type of messagelistener- for messages- Returns:
- locally unique listener id
- See Also:
Config.setReliableTopicWatchdogTimeout(long),MessageListener
-
removeListener
public void removeListener(String... listenerIds)
Description copied from interface:RReliableTopicRemoves the listener byidfor listening this topic- Specified by:
removeListenerin interfaceRReliableTopic- Parameters:
listenerIds- - listener ids
-
removeAllListeners
public void removeAllListeners()
Description copied from interface:RReliableTopicRemoves all listeners from this topic- Specified by:
removeAllListenersin interfaceRReliableTopic
-
removeAllListenersAsync
public RFuture<Void> removeAllListenersAsync()
Description copied from interface:RReliableTopicAsyncRemoves all listeners from this topic- Specified by:
removeAllListenersAsyncin interfaceRReliableTopicAsync
-
size
public long size()
Description copied from interface:RReliableTopicAmount of messages stored in Redis Stream object.- Specified by:
sizein interfaceRReliableTopic- Returns:
- amount of messages
-
sizeAsync
public RFuture<Long> sizeAsync()
Description copied from interface:RReliableTopicAsyncAmount of messages stored in Redis Stream object.- Specified by:
sizeAsyncin interfaceRReliableTopicAsync- Returns:
- amount of messages
-
countListeners
public int countListeners()
Description copied from interface:RReliableTopicReturns amount of registered listeners to this topic- Specified by:
countListenersin interfaceRReliableTopic- Returns:
- amount of listeners
-
publishAsync
public RFuture<Long> publishAsync(Object message)
Description copied from interface:RReliableTopicAsyncPublish the message to all subscribers of this topic asynchronously. Each subscriber may have multiple listeners.- Specified by:
publishAsyncin interfaceRReliableTopicAsync- Parameters:
message- to send- Returns:
- number of subscribers that received the message
-
generateId
protected String generateId()
-
addListenerAsync
public <M> RFuture<String> addListenerAsync(Class<M> type, MessageListener<M> listener)
Description copied from interface:RReliableTopicAsyncSubscribes to this topic.MessageListener.onMessagemethod is called when any message is published on this topic.Watchdog is started when listener was registered.
- Specified by:
addListenerAsyncin interfaceRReliableTopicAsync- Type Parameters:
M- - type of message- Parameters:
type- - type of messagelistener- for messages- Returns:
- locally unique listener id
- See Also:
Config.setReliableTopicWatchdogTimeout(long),MessageListener
-
deleteAsync
public RFuture<Boolean> deleteAsync()
Description copied from interface:RObjectAsyncDelete object in async mode- Specified by:
deleteAsyncin interfaceRObjectAsync- Overrides:
deleteAsyncin classRedissonObject- Returns:
trueif object was deletedfalseif not
-
sizeInMemoryAsync
public RFuture<Long> sizeInMemoryAsync()
Description copied from interface:RObjectAsyncReturns bytes amount used by object in Redis memory.- Specified by:
sizeInMemoryAsyncin interfaceRObjectAsync- Overrides:
sizeInMemoryAsyncin classRedissonObject- Returns:
- size in bytes
-
expireAsync
public RFuture<Boolean> expireAsync(long timeToLive, TimeUnit timeUnit)
Description copied from interface:RExpirableAsyncSet a timeout for object in async mode. After the timeout has expired, the key will automatically be deleted.- Specified by:
expireAsyncin interfaceRExpirableAsync- Parameters:
timeToLive- - timeout before object will be deletedtimeUnit- - timeout time unit- Returns:
trueif the timeout was set andfalseif not
-
clearExpireAsync
public RFuture<Boolean> clearExpireAsync()
Description copied from interface:RExpirableAsyncClear an expire timeout or expire date for object in async mode. Object will not be deleted.- Specified by:
clearExpireAsyncin interfaceRExpirableAsync- Returns:
trueif the timeout was cleared andfalseif not
-
removeListenerAsync
public RFuture<Void> removeListenerAsync(String... listenerIds)
Description copied from interface:RReliableTopicAsyncRemoves the listener byidfor listening this topic- Specified by:
removeListenerAsyncin interfaceRReliableTopicAsync- Parameters:
listenerIds- - listener ids- Returns:
- void
-
countSubscribers
public int countSubscribers()
Description copied from interface:RReliableTopicReturns amount of subscribers to this topic across all Redisson instances. Each subscriber may have multiple listeners.- Specified by:
countSubscribersin interfaceRReliableTopic- Returns:
- amount of subscribers
-
countSubscribersAsync
public RFuture<Integer> countSubscribersAsync()
Description copied from interface:RReliableTopicAsyncReturns amount of subscribers to this topic across all Redisson instances. Each subscriber may have multiple listeners.- Specified by:
countSubscribersAsyncin interfaceRReliableTopicAsync- Returns:
- amount of subscribers
-
expire
public boolean expire(long timeToLive, TimeUnit timeUnit)Description copied from interface:RExpirableSet a timeout for object. After the timeout has expired, the key will automatically be deleted.- Specified by:
expirein interfaceRExpirable- Parameters:
timeToLive- - timeout before object will be deletedtimeUnit- - timeout time unit- Returns:
trueif the timeout was set andfalseif not
-
expireAt
public boolean expireAt(long timestamp)
Description copied from interface:RExpirableUseRExpirable.expire(Instant)instead- Specified by:
expireAtin interfaceRExpirable- Parameters:
timestamp- - expire date in milliseconds (Unix timestamp)- Returns:
trueif the timeout was set andfalseif not
-
expireAtAsync
public RFuture<Boolean> expireAtAsync(long timestamp)
Description copied from interface:RExpirableAsyncUseRExpirableAsync.expireAsync(Instant)instead- Specified by:
expireAtAsyncin interfaceRExpirableAsync- Parameters:
timestamp- - expire date in milliseconds (Unix timestamp)- Returns:
trueif the timeout was set andfalseif not
-
expire
public boolean expire(Instant instant)
Description copied from interface:RExpirableSet an expire date for object. When expire date comes the key will automatically be deleted.- Specified by:
expirein interfaceRExpirable- Parameters:
instant- - expire date- Returns:
trueif the timeout was set andfalseif not
-
expireAsync
public RFuture<Boolean> expireAsync(Instant instant)
Description copied from interface:RExpirableAsyncSet an expire date for object. When expire date comes the key will automatically be deleted.- Specified by:
expireAsyncin interfaceRExpirableAsync- Parameters:
instant- - expire date- Returns:
trueif the timeout was set andfalseif not
-
expireAt
public boolean expireAt(Date timestamp)
Description copied from interface:RExpirableUseRExpirable.expire(Instant)instead- Specified by:
expireAtin interfaceRExpirable- Parameters:
timestamp- - expire date- Returns:
trueif the timeout was set andfalseif not
-
expireAtAsync
public RFuture<Boolean> expireAtAsync(Date timestamp)
Description copied from interface:RExpirableAsyncUseRExpirableAsync.expireAsync(Instant)instead- Specified by:
expireAtAsyncin interfaceRExpirableAsync- Parameters:
timestamp- - expire date- Returns:
trueif the timeout was set andfalseif not
-
clearExpire
public boolean clearExpire()
Description copied from interface:RExpirableClear an expire timeout or expire date for object.- Specified by:
clearExpirein interfaceRExpirable- Returns:
trueif timeout was removedfalseif object does not exist or does not have an associated timeout
-
remainTimeToLive
public long remainTimeToLive()
Description copied from interface:RExpirableRemaining time to live of Redisson object that has a timeout- Specified by:
remainTimeToLivein interfaceRExpirable- Returns:
- time in milliseconds -2 if the key does not exist. -1 if the key exists but has no associated expire.
-
remainTimeToLiveAsync
public RFuture<Long> remainTimeToLiveAsync()
Description copied from interface:RExpirableAsyncRemaining time to live of Redisson object that has a timeout- Specified by:
remainTimeToLiveAsyncin interfaceRExpirableAsync- Returns:
- time in milliseconds -2 if the key does not exist. -1 if the key exists but has no associated expire.
-
expireAsync
protected RFuture<Boolean> expireAsync(long timeToLive, TimeUnit timeUnit, String... keys)
-
-