文本文件在MongoDB中的存储大小

本文探讨了在MongoDB中存储CSV文件的磁盘占用情况。通过测试,发现相对于原始4.6GB的CSV文件,MongoDB在存储时有154.67MB的ObjectID额外开销,扣除后有约5.6倍的压缩比例。启用ignoreBlanks参数可减少空数据占用,小header可进一步节省空间,但可能丢失空列信息。测试结果对于MongoDB服务器的硬盘规格选择提供了参考。
摘要由CSDN通过智能技术生成

前言

项目中使用MongoDB存储文本数据,通过pymongo连接DB提供python查询接口。原始文件每天增长,项目需要评估MongoDB服务器使用什么规格的硬盘,那么当文本文件存入MongoDB后,相比原始文件,MongoDB磁盘占用多少,压缩率如何,怎么可以优化磁盘占用空间。本文尝试解答这些问题。

测试步骤

测试文件:

csv文件,13,515,366行,22列
文件大小: 4.6G

(csv文件使用mongodb是因为不同的csv文件中列是不同的)

测试方法:

测试三种情况下,MongoDB中collection大小情况。

  1. 使用mongoimport将数据导入MongoDB
  2. 在第一情况下,enable mongoimport的ignoreBlanks参数
  3. 将csv文件的header都改为比较小的,如c1,c2,…,c22。

在mongo shell中查看collection的状态信息。

db.your_collection.stats
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值