BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

LedisDB——Go编写的高性能NoSQL数据库

| 作者 马德奎 关注 0 他的粉丝 发布于 2014年8月14日. 估计阅读时间: 3 分钟 | Google、Facebook、Pinterest、阿里、腾讯 等顶尖技术团队的上百个可供参考的架构实例!

在7月24号发布0.1版本后,8月5号LedisDB 0.2版本发布。LedisDB是一个用Go语言编写的高性能NoSQL数据库,它支持多种高级数据结构,如kv、list、hash、zset、bitmap,也许可以作为Redis的替代方案。

LedisDB现在支持多种后台数据库,包括LevelDB、goleveldb、LMDB、RocksDB和BoltDB。用户可以通过测试选择一种合适的。如果用户没有进行配置,那么它将默认使用goleveldb来存储数据。它提供了两种设置存储数据库的方式,一种方式是在服务器配置文件中设定:

db_name = "leveldb"

另一种方式是在命令标志中指定:

ledis-server -config=/etc/ledis.conf -db_name=leveldb

第二种方式会覆盖第一种方式。但有一点必须注意,在运行时更改存储数据库非常危险,如果这样做,那么LedisDB将不会保证数据有效性。

LedisDB使用toml作为首选配置格式,不过,因为某些历史原因它也支持json。LedisDB源代码中的基本配置./etc/ledis.conf可以提供一些参考。当然,用户也可以不进行配置,它会使用默认配置。

LedisDB还有其它若干重要的特性:

  • 存储大量的数据,而无需考虑内存瓶颈。
  • 支持失效和TTL。
  • 直接支持Redis客户端,如redis-cli。
  • 支持多种客户端,包括Go、Python和Lua(OpenResty),后续还会增加对C/C++客户端API的支持。
  • 可以方便地嵌入用户自己的Go应用程序。
  • 支持Restful API及json/bson/msgpack输出格式。
  • 复制以保证数据安全。
  • 提供加载、转储和修复数据库的工具。

几天前的一次基准测试得出了这样的结论:

  • LedisDB使用leveldb和rocksdb作为后台存储数据库时比Redis或SSDB略慢。
  • 在LedisDB支持的数据库中,Imdb的表现要好于其它数据库,尤其是zrange*操作。

虽然测试结果不尽如人意,但它仍然是生产环境中的一种可选NoSQL方案。最后,还有一点需要注意,LedisDB现在更改了数据库保存路径。对于LevelDB,存储路径为data­­­_dir/leveldb;对于LMDB,存储路径为data­­_dir/lmdb。

要了解更多关于LedisDB的细节,可以登录GitHub及其官方网站。此外,作者还提供了中文博客


感谢郭蕾对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

NoSQL by 林 足雄

LedisDB 只是一个key-value storage.
连RDBMS都算不上, 怎么称之为Not Only SQL?

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

1 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT