04.03.2017
Konst: A library for stable hashing
Here is how load balancing works: To distribute requests among servers using consistent hashing, a proxy takes a hash of part of the request (in our case, the part of the URL that contains the video ID), and uses that hash to choose an available backend server.
With traditional “modulo hashing”, you simply consider the request hash as a
very large number. If you take that number modulo the number of available servers, you get the index of the server to use. But this idea is quite limited and it's not realistic in the modern web. The problem is that then number of servers is not constant. A server can fail, a new server might be added when there is more traffic. Traditional hashing approaches "solve" this problem by rehashing (remapping) the data to the new list of servers from scratch. That's slow!
Then there’s consistent hashing. Consistent hashing uses a more elaborate
scheme - a hash ring. In a hash ring, each server is assigned multiple hash
values based on its name or ID, and each request is assigned to the server
with the “nearest” hash value. The benefit of this added complexity is
that when a server is added or removed, most requests will map to the same
server that they did before.So if you have nine servers and add a tenth,
about 1/10 of requests will have hashes that fall near the newly-added
server’s hashes, and the other 9/10 will have the same nearest server that
they did before.
In the video a modular implementation of such data structure in ES6.
In addition, it is shown that Konst extends existing stable hashing packages
in npm since it permits the user of the library to specify his hashing
algorithms upon initializing without assuming a fixed one as most of npm
packages currently do.
Project Members: Konstantinos Pouliasis