Simple clustering by consensus library
Project description
Konsensus
A simple clustering by consensus library in Python. This is a simple implementation of a replicated state machine using a Paxos-derived algorithm.
Getting Started
Ensure you have the following first before you proceed:
-
You will require Python 3.10+ to run this project. If you are using a different version of Python, you will need to update your Python version to 3.10+. You can check your Python version by running
python --version
in your terminal. There are ways to install different versions of Python on your system and this can be done using pyenv. -
Poetry is a Python package manager that is used to manage dependencies. You can check the installation instructions in the link provided to get this setup.
-
Not a hard requirement as poetry should setup a virtual environment for you, but can be used as well to setup a virtual environment.
Once you have dependencies setup, run the below command to install dependencies:
poetry install
Even though this implementation has 0 dependencies to external packages, the dev packages are used for linting & handling tests. Therefore, this is useful when running linting & test commands.
The library itself is in the konsensus directory.
Running
There is a simple script in the project root run.py that contains a sample setup on how to use the library. It can be run with:
python run.py 10
10 is the seed value, this can be any other value like 20 or 30, etc
There are other scripts available in the Makefile that can be used to run formatting, linting, test or build commands.
Built With
Tool | Purpose |
---|---|
Python | Programming Language |
Poetry | Dependency & Package manager |
Contributing
Please read the contributing guide to learn how to contribute to this project.
Versioning
Semantic versioning is used to track the version of the project.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for konsensus-0.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e08d9d14919dc3f493df6507a29a1b9c6b22c57126e3763781f66a55466c56d4 |
|
MD5 | 87de54044452dc32a8dc0636a1e1ea27 |
|
BLAKE2b-256 | 46c17a019bfca532c9e5b95c8e1c4de7ebb59a732430c89599ac8b0c6815797a |