Package org.apache.zookeeper.server
Class ExpiryQueue<E>
- java.lang.Object
- 
- org.apache.zookeeper.server.ExpiryQueue<E>
 
- 
 public class ExpiryQueue<E> extends Object ExpiryQueue tracks elements in time sorted fixed duration buckets. It's used by SessionTrackerImpl to expire sessions and NIOServerCnxnFactory to expire connections.
- 
- 
Constructor SummaryConstructors Constructor Description ExpiryQueue(int expirationInterval)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voiddump(PrintWriter pwriter)Map<Long,Set<E>>getExpiryMap()Returns an unmodifiable view of the expiration time -> elements mapping.longgetWaitTime()Set<E>poll()Remove the next expired set of elements from expireMap.Longremove(E elem)Removes element from the queue.Longupdate(E elem, int timeout)Adds or updates expiration time for element in queue, rounding the timeout to the expiry interval bucketed used by this queue.
 
- 
- 
- 
Method Detail- 
removepublic Long remove(E elem) Removes element from the queue.- Parameters:
- elem- element to remove
- Returns:
- time at which the element was set to expire, or null if it wasn't present
 
 - 
updatepublic Long update(E elem, int timeout) Adds or updates expiration time for element in queue, rounding the timeout to the expiry interval bucketed used by this queue.- Parameters:
- elem- element to add/update
- timeout- timout in milliseconds
- Returns:
- time at which the element is now set to expire if changed, or null if unchanged
 
 - 
getWaitTimepublic long getWaitTime() - Returns:
- milliseconds until next expiration time, or 0 if has already past
 
 - 
pollpublic Set<E> poll() Remove the next expired set of elements from expireMap. This method needs to be called frequently enough by checking getWaitTime(), otherwise there will be a backlog of empty sets queued up in expiryMap.- Returns:
- next set of expired elements, or an empty set if none are ready
 
 - 
dumppublic void dump(PrintWriter pwriter) 
 
- 
 
-