deb-python-kafka/kafka/partitioner/base.py

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')