According to the blog entry of Richard Jones, the most mature distributed stores are:
Despite being the winner of Richard Jones’ comparison, Voldemort presents several drawbacks:
- JVM-only API
- purely key-value, no structured storage
- no dynamic group membership
Dynomite is currently used in production at powerset.com to serve images and supports thrift clients, dynamic adding of nodes. Unlike Voldemort it keeps all of the read repair, replication, and concurrency in the server, keeping the client code as simple as possible. Although this project seems very interesting, I would like to see operational reports from Microsoft about its scalabiliy and performance.
Currently, Scalaris has no disk persistence: the system works only in-memory. They reported the following performance: 2500 transactions per second with 16 servers. Voldemort reports much better performance.
An issue with Scalaris as mentionned by Werner Vogels is that under realistic failures scenarios, even with 3 phase paxos, commit consitency can only be guaranteed by not taking writes. Hence, Scalaris could not be used in a sales-oriented environment like Amazon where write availability is more important than consistency.
Cassandra is not part of Richard Jones’ winner list due to the fact that the community and documentation about it is not much present.
Cassandra was accepted into Apache Incubator on 02.01.2009. I think that the community around Cassandra will quickly grow during the next months. Moreover, the mailing lists are already more active that those of Voldemort. Here is a summary of its design choices and architecture.
Cassandra has some advantages over Voldemort:
- provides structured storage (not only key-value as Voldemort)
- Voldemort does not support dynamic group membership: one may not
be able to add nodes to the cluster without bringing the cluster down. Cassandra uses dynamic group membership algorithm based on Gossip.
- Thrift as a client protocol, and not only JVM API. Thrift was also accepted into Apache Incubator.
- Hadoop integration