开发者

Any tips for creating a key value store abstraction layer? [closed]

开发者 https://www.devze.com 2022-12-20 17:57 出处:网络
Closed. This question needs to be more focused. It is not currently accepting answers. 开发者_如何学Go
Closed. This question needs to be more focused. It is not currently accepting answers. 开发者_如何学Go

Want to improve this question? Update the question so it focuses on one problem only by editing this post.

Closed 4 years ago.

Improve this question

With all the key value data stores out there I have started to create an abstraction layer so that a developer does not have to be tied in to a particular store. I propose to make libraries for:

Erlang
Ruby
Java
.NET

Does anyone have any tips on how I should go about designing this API?

Thanks


First off, and as a general rule for anytime you build "pluggable" abstraction layer, build it to support at least two real implementations to start. Don't build it for just one datastore and try to make it abstracted, because you'd overlook a details that won't plug into another implementation very well. By forcing it to use two seperate implementations, you'll get closer to something that is actually flexible, but you'll have to make further changes to support a third and fourth data store.

Second, don't bother, these things already exist. Microsoft has provided a ton of these for their technologies (ODBC, ADO, ADO.NET, etc), and I'm sure Ruby/Java/etc has several as well. I understand the desire to encapsulate the already existing technology, but the more data stores you need to support, the more complexity you need to build in, and the closer you'll get to ADO.NET (or similar technologies). Companies like MS have spent a ton of money and research on solving this exact problem, and that is what they came up with.


I would strongly recommend checking out Twitter's Storehaus project - this is a key-value store abstraction layer for the JVM and written in Scala, supporting (to date) Memcache, Redis, DynamoDB, MySQL, HBase, Elasticsearch and Kafka.

Storehaus's core module defines three traits:

  1. A read-only ReadableStore with get, getAll and close
  2. A write-only WritableStore with put, putAll and close
  3. A read-write Store combining both

In the Ruby ecosystem, you should check out moneta, which again provides a unified interface to key/value stores. It has a lot more features than Storehaus.

0

精彩评论

暂无评论...
验证码 换一张
取 消