28 lines
		
	
	
		
			906 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			906 B
		
	
	
	
		
			Python
		
	
	
	
	
	
from __future__ import absolute_import
 | 
						|
 | 
						|
 | 
						|
class Partitioner(object):
 | 
						|
    """
 | 
						|
    Base class for a partitioner
 | 
						|
    """
 | 
						|
    def __init__(self, partitions=None):
 | 
						|
        """
 | 
						|
        Initialize the partitioner
 | 
						|
 | 
						|
        Arguments:
 | 
						|
            partitions: A list of available partitions (during startup) OPTIONAL.
 | 
						|
        """
 | 
						|
        self.partitions = partitions
 | 
						|
 | 
						|
    def __call__(self, key, all_partitions=None, available_partitions=None):
 | 
						|
        """
 | 
						|
        Takes a string key, num_partitions and available_partitions as argument and returns
 | 
						|
        a partition to be used for the message
 | 
						|
 | 
						|
        Arguments:
 | 
						|
            key: the key to use for partitioning.
 | 
						|
            all_partitions: a list of the topic's partitions.
 | 
						|
            available_partitions: a list of the broker's currently avaliable partitions(optional).
 | 
						|
        """
 | 
						|
        raise NotImplementedError('partition function has to be implemented')
 |