All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.distexec.mapreduce.MapReduceManager Maven / Gradle / Ivy

package org.infinispan.distexec.mapreduce;

import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ExecutorService;

import org.infinispan.commands.read.MapCombineCommand;
import org.infinispan.commands.read.ReduceCommand;
import org.infinispan.distribution.DistributionManager;
import org.infinispan.remoting.transport.Address;

/**
 * MapReduceManager is an internal Infinispan component receiving map/reduce invocations arriving
 * from remote Infinispan nodes.
 * 

* * This interface should never be implemented by clients. * * @author Vladimir Blagojevic * @since 5.2 */ public interface MapReduceManager { /** * Invoked when MapCombineCommand arrives to a target Infinispan node and returns set of * intermediate keys that needs to be reduced. * * @param mcc MapCombineCommand sent from MapReduceTask * @return a set of intermediate keys to be reduced distributively */ Set mapAndCombineForDistributedReduction( MapCombineCommand mcc) throws InterruptedException; /** * Invoked when MapCombineCommand arrives to a target Infinispan node and returns map of resulting * values that need to be reduced. *

* Unlike {@link #mapAndCombineForDistributedReduction(MapCombineCommand)} * implementations should return a map Map> which should be ready for reduction * at master Infinispan node *

* * @param mcc MapCombineCommand sent from MapReduceTask * @return a map Map> which should be ready for reduction * at master Infinispan node */ Map> mapAndCombineForLocalReduction( MapCombineCommand mcc) throws InterruptedException; /** * Invoked when ReduceCommand arrives to a target Infinispan node. Implementations should return * a map of reduced output keys and values to be returned to invoker of MapReduceTask * * @param reducer ReduceCommand sent from MapReduceTask * @return map of reduced output keys and values returned to MapReduceTask */ Map reduce(ReduceCommand reducer) throws InterruptedException; /** * Invoked when ReduceCommand arrives to a target Infinispan node. However, instead of returning * a resulting Map to master node, reduce command emits results of reduce phase to a * specified resulting cache. * * @param reducer ReduceCommand sent from MapReduceTask * @param resultCache result cache to store results of reduce phase * @return map of reduced output keys and values returned to MapReduceTask */ void reduce(ReduceCommand reducer, String resultCache) throws InterruptedException; /** * Maps Map/Reduce task intermediate or input keys to nodes on Infinispan cluster * * * @param dm * distribution manager to use for locating keys on hash wheel * @param taskId * id of the map/reduce task * @param keysToMap * list of input keys to locate in the cluster * @return map where each key is an Address in the cluster and value are the keys mapped to that * Address */ Map> mapKeysToNodes(DistributionManager dm, String taskId, Collection keysToMap); /** * ExecutorService provided for local task execution * * @return {@link ExecutorService} for local tasks */ ExecutorService getExecutorService(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy