Package org.apache.lucene.store
Class RateLimiter.SimpleRateLimiter
java.lang.Object
org.apache.lucene.store.RateLimiter
org.apache.lucene.store.RateLimiter.SimpleRateLimiter
- Enclosing class:
- RateLimiter
Simple class to rate limit IO.
- 
Nested Class SummaryNested classes/interfaces inherited from class org.apache.lucene.store.RateLimiterRateLimiter.SimpleRateLimiter
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptiondoubleThe current mb per second rate limit.longHow many bytes caller should add up itself before invokingRateLimiter.pause(long).longpause(long bytes) Pauses, if necessary, to keep the instantaneous IO rate at or below the target.voidsetMBPerSec(double mbPerSec) Sets an updated mb per second rate limit.
- 
Constructor Details- 
SimpleRateLimiterpublic SimpleRateLimiter(double mbPerSec) mbPerSec is the MB/sec max IO rate
 
- 
- 
Method Details- 
setMBPerSecpublic void setMBPerSec(double mbPerSec) Sets an updated mb per second rate limit.- Specified by:
- setMBPerSecin class- RateLimiter
 
- 
getMinPauseCheckBytespublic long getMinPauseCheckBytes()Description copied from class:RateLimiterHow many bytes caller should add up itself before invokingRateLimiter.pause(long). NOTE: The value returned by this method may change over time and is not guaranteed to be constant throughout the lifetime of the RateLimiter. Users are advised to refresh their local values with calls to this method to ensure consistency.- Specified by:
- getMinPauseCheckBytesin class- RateLimiter
 
- 
getMBPerSecpublic double getMBPerSec()The current mb per second rate limit.- Specified by:
- getMBPerSecin class- RateLimiter
 
- 
pausepublic long pause(long bytes) Pauses, if necessary, to keep the instantaneous IO rate at or below the target. Be sure to only call this method when bytes >getMinPauseCheckBytes(), otherwise it will pause way too long!- Specified by:
- pausein class- RateLimiter
- Returns:
- the pause time in nano seconds
 
 
-