Skip to main content

Implements consistent hashing with Python and the algorithm is the same as libketama.

Project description

consistent-hash

Implements consistent hashing that can be used when the number of server nodes can increase or decrease.The algorithm that is used for consistent hashing is the same as libketama <https://github.com/RJ/ketama>

Usage

It’s so easy to use^_^:

from consistent_hash import ConsistentHash

# You can construct consistent hash with the below three ways
con_hash = ConsistentHash({'192.168.0.101:11212':1, '192.168.0.102:11212':2, '192.168.0.103:11212':1})
# Or
con_hash = ConsistentHash(['192.168.0.101:11212', '192.168.0.102:11212', '192.168.0.103:11212']))
# Or
con_hash = ConsistentHash('192.168.0.101:11212')

# Add servers to hash ring
con_hash.add_nodes({'192.168.0.104:11212':1})
# Get a server via the key of object
server = con_hash.get_node('my_key')
# Delete the server from hash ring, you don't need to indicate weights
con_hash.del_nodes(['192.168.0.102:11212', '192.168.0.104:11212'])

Unit test

  • Firstly, install nose which extends unittest to make testing easier:

    pip install nose
  • Then, run tests:

    # Option -s any stdout output will be printed immediately
    # and -v be more verbose
    nosetests -s -v

More information about nose <https://nose.readthedocs.org/en/latest/>

Project details


Release history Release notifications | RSS feed

This version

1.0

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

consistent_hash-1.0.tar.gz (3.7 kB view details)

Uploaded Source

Built Distribution

consistent_hash-1.0-py2.7.egg (6.8 kB view details)

Uploaded Source

File details

Details for the file consistent_hash-1.0.tar.gz.

File metadata

File hashes

Hashes for consistent_hash-1.0.tar.gz
Algorithm Hash digest
SHA256 d9f88eff086680918b458b62994fbf07ef97736771f1e9f3b05855547636a7ac
MD5 4f18a0df135ef4416029f6d733738c68
BLAKE2b-256 26bec87797f4c4d941486747997608c425d5a47e9fcc3da27759fd00488b0e2e

See more details on using hashes here.

File details

Details for the file consistent_hash-1.0-py2.7.egg.

File metadata

File hashes

Hashes for consistent_hash-1.0-py2.7.egg
Algorithm Hash digest
SHA256 adc3bf7cba13dd2cabe50c5d4507d9a8a3ff2610b6801e88acf73d158946658d
MD5 0c0d8ce9976d0283da26783dc543006f
BLAKE2b-256 d4f49dfe91d8b7585e0b08c3ec11f7387bc996c6a721b7d3cd5cc9402436a80b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page