TomP2P | |
Latest Release Version: | 4.4 |
Developer: | Thomas Bocek |
Programming Language: | Java |
Genre: | peer-to-peer, key-value store |
License: | Apache License 2 |
TomP2P is a distributed hash table which provides a decentralized key-value infrastructure for distributed applications. Each peer has a table that can be configured either to be disk-based or memory-based to store its values.
TomP2P stores key-value pairs in a distributed hash table. To find the peers and store the data in the distributed hash table, TomP2P uses an iterative routing approach. The underlying protocol for all the communication with other peers uses state-less request-reply messaging. Since TomP2P uses non-blocking communication, a future object is required to keep track of future results. This key concept is used for all the communication (iterative routing and DHT operations, such as storing a value on multiple peers) in TomP2P and it is also exposed in the API. Thus, an operation such as get(...)
or put(...)
will return immediately and the user of the API can either block the operation to wait for the completion or add a listener that gets notified when the operation completes.