2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

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:4110824
用户头像

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

关注

评论

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

百万技术博主实测:AI+Java 一键写程序 ,写一句代码算我输

飞算JavaAI开发助手

坚持科技创新发展 天翼云“息壤”构筑国云智能底座

极客天地

飞算 JavaAI:支持复杂业务逻辑生成,降低 80% 开发门槛

飞算JavaAI开发助手

NetScaler Console 14.1 Build 43.50 (ESXi, Hyper-V, KVM, Xen) - 集中管理 NetScaler

sysin

NetScaler

前端如何通过 AI+低代码 提升开发体验

秃头小帅oi

iPaaS集成平台与ESB在应用场景上的区别

谷云科技RestCloud

ESB API 数据集成平台 ipaas 软件集成

Databend Cloud 通过 SOC 2 和 GDPR 认证,助力用户实现数据安全与隐私保护的双重保障

Databend

从抵触到真香:95 后程序员用飞算 JavaAI 实现效率翻倍

飞算JavaAI开发助手

Mac上NTFS读写工具有哪些,读写软件NTFS哪个好?

阿拉灯神丁

Mac软件 Paragon NTFS NTFS 磁盘管理器 Tuxera NTFS2024 磁盘格式读写软件

NetScaler 14.1 Build 43.50 (nCore, VPX, SDX, CPX, BLX) - 混合多云应用交付控制器

sysin

NetScaler

在Docker中部署DataKit最佳实践

观测云

Docker

企业级数据可视化的范式演进:基于低代码平台的动态响应式设计方法论

不在线第一只蜗牛

低代码

飞算 JavaAI 如何让微服务开发快人一步?

飞算JavaAI开发助手

揭秘!软件测试开发质量衡量标准全攻略!

不在线第一只蜗牛

软件开发

企业如何搭建技术支持体系?盘点三个需重点关注的方面

贝锐

远控工具 办公 办公效率

Windows 11 绕过 TPM 方法总结,通用免 TPM 镜像下载 (2025 年 2 月更新)

sysin

GpuGeek亮相第三届北京人工智能产业创新发展大会

极客天地

如何选择最适合企业持续发展的财务规划方式?

智达方通

企业管理 全面预算管理 财务规划

告别重复造轮子!飞算 JavaAI 一键生成工程代码

飞算JavaAI开发助手

国民级产品百度网盘大动作!接入DeepSeek-R1满血版,实现文件秒搜,轻松搭建、管理、调用个人知识库

极客天地

Splunk Enterprise 9.4.1 (macOS, Linux, Windows) - 机器数据管理和分析

sysin

Splunk Enterprise

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