mongo 2.6.3释放已删除mongodb集合空间方法是什么
使用mongodb有几个月,数据一直在不断累加,现在mongodb已经200G,我试图删除一些数据,但是mongodb并没有释放那些空间。
查资料显示需要使用 db.repairDatabase(),但是出现了一个错误:
"Cannot repair database db_wallpaper having size: 212447789056 (bytes) because free disk space is: 157012410368 (bytes)"。
硬盘空间不足以空出200G... 该怎么办...
mongo: 2.6.3
亲测解决方案:
导出前, 删除mongo里面不需要的数据表和内容, 再执行以下操作.
使用Linux 下shell命令:
mongodump -o /xxx/xxx
我导出全部数据库, 原本数据库占空间越200G, 导出后为48G, 耗时3天左右
进入mongodb 数据库文件目录, 默认为 /var/lib/mongodb/, 可在/etc/mongod.conf 查看你的目录地址, 删除整个文件夹, 再新建该文件夹, 注意修改文件夹权限为mongodb用户.(chown命令)
再使用mongostore, 恢复后占空间90G左右, 耗时16小时
mongorestore -d database_name /xxx/xxx
以上操作均在远程服务器完成.
另, 非常感谢@huandu的建议!!
比较慢的方法:可以尝试给这个数据库增加一个 replica-set,等新加的结点和老数据同步了之后就可以停掉老数据库并删除老数据,以新结点对外提供服务,此时数据库空间应该已经整理好并压缩到最小了。这个过程自己并不可控,200 GB 的话要同步多久无法预估,但是不会太影响 mongodb 继续提供服务。
比较快的方法:用 mongodump/mongoexport 导出所有数据,可以远程导出,倒完之后再用 mongorestore/mongoimport 恢复数据。这个操作会导致 mongodb 锁数据库,无法对外提供服务,如果锁了也无所谓可以用这个方法,200 GB 说不定需要小半天的时间,得自己估量一下。
另外,db.repairDatabase()
效果很有限,且会导致长时间锁数据库,不用为好。mongodb 解决磁盘问题比较好的方法是用 auto-sharding 将数据分摊到多台机器上,不过这个事情得提前计划好,一旦数据库已经非常大了,能做的事情就很少了。
官方文档上有说明:
如果当前磁盘分区空间不足,可以尝试用 --repairpath
参数指定一个空间足够的分区路径
在100G的时候,你就该作清理工作
至少,在知道数据量大的时候,你就该准备相关的知识
玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd19067.html
相关文章 Recommend
- • 怎么样可以有效避免MongoDB注入时产生的一系列问
- • MongoEngine怎样更新列表数据至MongoDB数据库中
- • MongoDB实现数据分页需要什么方法
- • pymongo 读取集合关联外键文档字段用什么方法
- • 如何优化python mongodb批量修改任务
- • python tornado mongo驱动应该如何选择
- • MongoDB/Mongoengin 如果设计一个课程表字段
- • python mongoengine条件查询比较字段方法求助
- • Python MongoDB正则与模糊查询出错
- • 请问Mongoengine如何查询ListField内不包含指定值的结
- • pymongo条件查询怎么写
- • Python处理mongodb遇到的document key相关问题
必知PYTHON教程 Must Know PYTHON Tutorials
- • python 解释器
- • python idle
- • python dir函数
- • python 数据类型
- • python type函数
- • python 字符串
- • python 整型数字
- • python 列表
- • python 元组
- • python 字典
- • python 集合
- • python 变量
- • python print
- • python 函数
- • python 类定义
- • python import
- • python help
- • python open
- • python 异常处理
- • python 注释
- • python continue
- • python pass
- • python return
- • python global
- • python assert
- • python if语句
- • python break
- • python for循环
- • python while循环
- • python else/elif
- • lambda匿名函数
必知PYTHON模块 Must Know PYTHON Modules
- • os 模块
- • sys 模块
- • re 正则表达式
- • time 日期时间
- • pickle 持久化
- • random 随机
- • csv 模块
- • logging 日志
- • socket网络通信
- • json模块
- • urlparse 解析URL
- • urllib 模块
- • urllib2 模块
- • robotparser 解析
- • Cookie 模块
- • smtplib 邮件
- • Base64 编码
- • xmlrpclib客户端
- • string 文本
- • Queue 线程安全
- • math数学计算
- • linecache缓存
- • threading多线程
- • sqlite3数据库
- • gzip压缩解压
最新内容 NEWS
- • django app提供pv信息的方法是什么
- • Django项目版本升级如何操作?
- • django较多数据传递如何优雅的呈现
- • django1.7获取参数问题求助
- • Django1.7使用内置comment遇到问题
- • python mysql数据库做insert操作时报_mysql_ex
- • 关于python mysql的duplicate insert机制的疑问
- • pymongo使用insert函数批量插入被中断要怎么
- • Python程序员解决棘手问题的常用库
- • 求助关于restfull api接口几个问题
图文精华 RECOMMEND
-
django1.7获取参数问题求助
-
Python程序员解决棘手问题的常用库
-
求问str()同__str__原理上有什么不同
-
scrapy框架里面用link extractor怎么能
-
python {}.fromkeys创建字典append添加操
-
python3 类型Type str doesn't support th
热点文章 HOT
- 学习Python有什么好的书籍推荐?
- Python匿名函数 Lambda表达式作用
- Python与Java、C、Ruby、PHP等编程语言有什么
- Python 正则中文网页字符串提取问题
- 如何为实时性应用存取经纬度?django my
- 想用python做个客户端,在二维码登录这个地
- 有让IDE可识别Python函数参数类型的方法吗
- Python字符串转换成列表正则疑问