Go 中 LevelDB 数据库大小缩减的问题 (levigo)
来源:stackoverflow
时间:2024-02-08 08:41:32 110浏览 收藏
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《Go 中 LevelDB 数据库大小缩减的问题 (levigo)》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!
问题内容Stack Overflow 社区您好,
我目前正在开发一个 Go 程序,该程序使用 levigo 包利用 LevelDB 进行数据存储。我的目标是有效管理数据库大小,特别是在可用存储空间不足时删除旧记录。但是,我观察到一个意外的行为:删除记录后,LevelDB 数据库文件夹大小并没有按比例减小。
这是重现该问题的代码的简化版本:
保存数据代码:
package main import ( "crypto/rand" "fmt" "log" "github.com/jmhodges/levigo" ) func main() { // Specify the LevelDB options options := levigo.NewOptions() cache := levigo.NewLRUCache(5 << 20) options.SetCache(cache) options.SetCreateIfMissing(true) options.SetMaxOpenFiles(100) // Open or create the LevelDB database db, _ := levigo.Open("/tmp/mydatabase", options) defer db.Close() dataSize := 1024 * 1024 * 5 // 5MB randomData := make([]byte, dataSize) rand.Read(randomData) // Enqueue 5 pieces of data for i := 1; i <= 5; i++ { key := []byte(fmt.Sprintf("key%d", i)) // Write the batch to the database if err := db.Put(levigo.NewWriteOptions(), key, randomData); err != nil { log.Fatal(err) } fmt.Printf("Enqueued: %s \n", key) } fmt.Println("Enqueue completed.") }
删除数据代码:
package main import ( "fmt" "log" "github.com/jmhodges/levigo" ) func main() { // Specify the LevelDB options options := levigo.NewOptions() cache := levigo.NewLRUCache(5 << 20) options.SetCache(cache) options.SetCreateIfMissing(true) options.SetMaxOpenFiles(100) // Open or create the LevelDB database db, _ := levigo.Open("/tmp/mydatabase", options) defer db.Close() // Dequeue (remove) the 3 pieces of data for i := 1; i <= 3; i++ { key := []byte(fmt.Sprintf("key%d", i)) // Create a WriteOptions for deleting from the database wo := levigo.NewWriteOptions() defer wo.Close() // Delete the key from the database if err := db.Delete(wo, key); err != nil { log.Fatal(err) } fmt.Printf("Dequeued: %s\n", key) } fmt.Println("Dequeue completed.") }
运行代码保存 5 项后,数据库文件夹大小为 30MB。随后,当我运行代码删除 3 个项目时,文件夹大小减少到 26MB。考虑到删除的数据量,我预计大小会更显着减小。
我已经设置了 LevelDB 选项,例如缓存大小和文件限制,但似乎我可能在配置或删除过程中遗漏了一些内容。
问题:
- 什么可能导致 LevelDB 数据库文件夹大小在删除记录后未按比例减小?
- 为了更有效地管理数据库大小,我是否应该考虑其他配置或优化?
- levigo中有没有特定的方法来压缩数据库以释放未使用的空间?
任何有关解决此问题的见解或指导将不胜感激。谢谢!
正确答案
通过阅读此level DB 存储库上的问题,我意识到我可以添加此内容删除循环末尾的行 db.CompactRange(levigo.Range{})
因此数据库将删除未使用的数据,并且数据库文件夹的总大小也会随之减小。
本篇关于《Go 中 LevelDB 数据库大小缩减的问题 (levigo)》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习