写点什么

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

  • 2014-08-13
  • 本文字数:943 字

    阅读完需:约 3 分钟

在 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 )关注我们,并与我们的编辑和其他读者朋友交流。

2014-08-13 02:4110432
用户头像

发布了 256 篇内容, 共 89.5 次阅读, 收获喜欢 12 次。

关注

评论

发布
暂无评论
发现更多内容

儿童成长自律表

wood

300天创作

模块六课程作业

李晓笛

模块六作业-拆分电商系统为微服务

CH

#架构实战营 「架构实战营」

云原生的前世今生(一)

劼哥stone

云原生

【优化技术专题】「系统性能调优实战」终极关注应用系统性能调优及原理剖析(上册)

洛神灬殇

Linux 性能调优 1月日更 系统优化 技术分析

Linux之kill命令

入门小站

Linux

跟着Apple、Google大佬学优化

admin

小程序 微信 性能优化 缓存;

架构实战营 4 期第六模块作业

jialuooooo

架构实战营

回归分析中的道与术

whatever

数据分析预测

微信朋友圈高性能复杂度分析

李大虾

#架构实战营 「架构实战营」

模块六

Geek_59dec2

架构

中间件厂商宝兰德加入,龙蜥社区迎来新伙伴

OpenAnolis小助手

Linux 开源

PyTorch:常见错误 inplace operation

强劲九

Python 人工智能 机器学习 深度学习 PyTorch

架构实战营第 4 期第 6 课作业:拆分电商系统为微服务

owl

架构实战营

[架构实战营] 模块七作业

Geek_0ed632

「架构实战营」

聊聊 JDBC 的 executeBatch || 对比下不同数据库对 JDBC batch 的实现细节

明哥的IT随笔

数据库 性能优化 MySQL 数据库

百度吴甜做客央视《对话》:AI技术加持显著降低数字人生产成本

百度大脑

Paxos 与 Raft 区别

努力努力再努力

架构训练营模块六作业

沈益飞

架构训练营

架构实战营4期-模块6作业

木几丶

「架构实战营」

模块六作业

Anlumina

架构实战营

「架构实战营」模块六《如何设计业务的微服务架构》作业

DaiChen

作业 模块六 「架构实战营」

2022新年Flag:用未来可能会发生的事情推断今天该做的事

宇宙之一粟

flag 1月月更

架构实战营模块六作业

zhongwy

架构实战营

「按需引入」的多种实现方式

百瓶技术

前端 webpack babel 按需加载

架构实战营 第 4 期 模块六作业

架构实战营 模块六 「架构实战营」

Bug Bash:Bug大扫除的正确用法

石云升

bug 1月月更 Bug Bash

【架构实战营】模块六:命题作业

wgl

「架构实战营」

拆分电商系统为微服务

AUV

「架构实战营」

第六周作业

cqyanbo

使用Cloud Application Programming模型开发OData的一个实际例子

汪子熙

API abap Cloud Studio 1月月更

LedisDB——Go编写的高性能NoSQL数据库_数据库_马德奎_InfoQ精选文章