Partitioner
Partitioners are defined by the following
trait Partitioner {
def find(key: Array[Byte], replicaCount: Int): List[MemberAddress]
}
An implementation of Partitioner is supposed to return the list of nodes where the given key should be placed if we need replicaCount
number of replicas.
Suuchi by default comes with a ConsistentHashPartitioner which uses ConsistentHashRing underneath to partition the data.
Interesting readings on Consistent Hash Ring
- http://blog.plasmaconduit.com/consistent-hashing/
- http://www.paperplanes.de/2011/12/9/the-magic-of-consistent-hashing.html
An example of CH Ring during assignment or replication.
data:image/s3,"s3://crabby-images/edede/edede1140225a3b0d4e93de618eead1e33feaa7e" alt="CH Ring"