Package org.apache.storm.localizer
Class AsyncLocalizer
- java.lang.Object
- 
- org.apache.storm.localizer.AsyncLocalizer
 
- 
- All Implemented Interfaces:
- AutoCloseable
 
 public class AsyncLocalizer extends Object implements AutoCloseable Downloads and caches blobs locally.
- 
- 
Field SummaryFields Modifier and Type Field Description protected longcacheTargetSizeprotected ConcurrentHashMap<String,ConcurrentHashMap<String,LocalizedResource>>userArchivesprotected ConcurrentHashMap<String,ConcurrentHashMap<String,LocalizedResource>>userFiles
 - 
Constructor SummaryConstructors Constructor Description AsyncLocalizer(Map<String,Object> conf, StormMetricsRegistry metricsRegistry)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()protected ClientBlobStoregetClientBlobStore()voidrecoverRunningTopology(LocalAssignment currentAssignment, int port, BlobChangingCallback cb)Do everything needed to recover the state in the AsyncLocalizer for a running topology.voidreleaseSlotFor(LocalAssignment assignment, int port)Remove this assignment/port as blocking resources from being cleaned up.CompletableFuture<Void>requestDownloadTopologyBlobs(LocalAssignment assignment, int port, BlobChangingCallback cb)Request that all of the blobs necessary for this topology be downloaded.voidstart()Start any background threads needed.
 
- 
- 
- 
Field Detail- 
userFilesprotected final ConcurrentHashMap<String,ConcurrentHashMap<String,LocalizedResource>> userFiles 
 - 
userArchivesprotected final ConcurrentHashMap<String,ConcurrentHashMap<String,LocalizedResource>> userArchives 
 - 
cacheTargetSizeprotected long cacheTargetSize 
 
- 
 - 
Constructor Detail- 
AsyncLocalizerpublic AsyncLocalizer(Map<String,Object> conf, StormMetricsRegistry metricsRegistry) throws IOException - Throws:
- IOException
 
 
- 
 - 
Method Detail- 
requestDownloadTopologyBlobspublic CompletableFuture<Void> requestDownloadTopologyBlobs(LocalAssignment assignment, int port, BlobChangingCallback cb) throws IOException Request that all of the blobs necessary for this topology be downloaded. Note that this adds references to blobs asynchronously in background threads.- Parameters:
- assignment- the assignment that needs the blobs
- port- the port the assignment is a part of
- cb- a callback for when the blobs change. This is only for blobs that are tied to the lifetime of the worker.
- Returns:
- a Future that indicates when they are all downloaded.
- Throws:
- IOException- if there was an error while trying doing it.
 
 - 
startpublic void start() Start any background threads needed. This includes updating blobs and cleaning up unused blobs over the configured size limit.
 - 
closepublic void close() throws InterruptedException- Specified by:
- closein interface- AutoCloseable
- Throws:
- InterruptedException
 
 - 
recoverRunningTopologypublic void recoverRunningTopology(LocalAssignment currentAssignment, int port, BlobChangingCallback cb) throws IOException Do everything needed to recover the state in the AsyncLocalizer for a running topology.- Parameters:
- currentAssignment- the assignment for the topology.
- port- the port the assignment is on.
- cb- a callback for when the blobs are updated. This will only be for blobs that indicate that if they change the worker should be restarted.
- Throws:
- IOException- on any error trying to recover the state.
 
 - 
releaseSlotForpublic void releaseSlotFor(LocalAssignment assignment, int port) throws IOException Remove this assignment/port as blocking resources from being cleaned up.- Parameters:
- assignment- the assignment the resources are for
- port- the port the topology is running on
- Throws:
- IOException- on any error
 
 - 
getClientBlobStoreprotected ClientBlobStore getClientBlobStore() 
 
- 
 
-