The solution : Consistent hashing (CH)
How does CH work ?
CH facilitates the distribution of data across a set of nodes (DB servers) in such a way that minimizes the mapping or reorganization of data when nodes are added or removed.
1- What is CH ? Creating th Hash Key Space.
We need to consider a hash function that generates integer hash values in the following range [0, 2^32-1] and the output of a hash function is: x0, x1, x2,…,xN.
data:image/s3,"s3://crabby-images/ee2da/ee2da7549f3377e754f3ac56aa75dae9d854308b" alt=""
2- Representing the hash space as a hash ring
By connecting both ends, we get a hash ring. So, we can visualize it as a ring.
data:image/s3,"s3://crabby-images/1e285/1e285efefb243cb8a7ed7df4775f93845d260852" alt=""
3- Hash servers : Placing DB servers in the hash ring
We can use the hash function and so, hash the servers on their IP address to map them to different integers.
data:image/s3,"s3://crabby-images/61b5c/61b5c1fbc8d0dff7f48bee7e5b3f0167fd9c2f53" alt=""
4- Hash Keys: Determining placement of keys on servers
To find which DB server an incoming key resides on : we assume we have 4 incoming keys (key0, key1, key2, key3) and none of them directly maps the hash value of any 4 servers on our ring. We follow the hand of a clock and insert the key.
data:image/s3,"s3://crabby-images/eb9e1/eb9e1e386b7a87a2ddd45a5da9047a2ee84e8b09" alt=""
5- Adding a server in the ring
When we add a server, we need to add it between server 0 and server 3. We'll need to remap only to remap the keys to the server 4 (new server).
So, we need to remap only k/n keys where k is the number of keys (4) and n is the number of servers (5).
data:image/s3,"s3://crabby-images/9a6eb/9a6eb6d0f5b35b703a0546691ff3d837e0681f3c" alt=""
6- Removing a server from the ring
A server might go down and our consistent hashing scheme ensures that it has minimal effect on the number of keys and servers affected. If server 0 goes down, only the keys between server 3 and server 0 will need to be remapped to server 1 : here, we have 2 keys to consider and the rest of the keys are unaffected.
data:image/s3,"s3://crabby-images/fb7d4/fb7d4aa20d250e17fa1336e46679bb1039460209" alt=""