码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • mongodb如何删除数据并释放空间


            mongodb删除数据后不会直接释放内存空间,是因为使用了一种称为“延迟删除”的策略。这意味着当一个文档被删除时,它仍然会占用一定的内存空间,直到这个空间被垃圾回收器(Garbage Collector)回收。

            删除数据操作前建议先评估你的操作会有什么样的影响。在生产上操作的时候,需要评估你删除的数据有多大,需要用多长时间,从而可以制定相应的实施和回退方案。

    举个例子,db是busi,我要删除createDate小于2023-07-01的数据,根据这个字段查询数据量大概有多少,或者可以根据主键_id来查询。

    -- 查询数据

    db.busi.find({createDate:{$gt : '2023-07-01'}}).count();
    db.busi.find({_id:{$gt: 123456}}).count()
    db.busi.find({_id:{$lt: 123456}}).count()

    如果符合预期的操作方案,则进行后面的删除;

    注意:删除数据只能在主节点进行操作

    -- 根据日期删除数据(时间较长)
    db.busi.remove({createDate:{$gt : '2023-07-01'}})

    删除过程中也可以直接查询当前的数据量


    -- 根据条件查询当前的数据总量
    db.busi.find({_id: {$gt: 123456}}).count();
    db.busi.find({_id: {$lt: 123456}}).count();
    -- 该语句执行较长
    db.busi.find({createDate: {$lt: '2023-07-01'}}).count();

    删除完成后,我们可以观察服务器对应的数据目录,磁盘空间是没有任何变化的,则需要执行下面的命令

    注意:释放空间只是释放了当前节点的空间,如果有多个节点,还需要在多个节点进行操作


    -- 释放空间(需要几分钟)
    db.runCommand({compact: "busi", force:true});
    -- 实时查询当前空间大小
    db.busi.stats().storageSize;

  • 相关阅读:
    Manopt使用
    csp 202212-2 训练计划
    算法 - 递归实现汉诺塔(The Tower of Hanoi)
    产品推荐 - 基于Xilinx Kintex-7 XC7K160T/325T/410T打造的水星Mercury+ KX2核心板
    深度学习入门之自动求导(Pytorch)
    Python实现WOA智能鲸鱼优化算法优化卷积神经网络回归模型(CNN回归算法)项目实战
    kubeadm初始化搭建cri-dockerd记录 containerd.io
    TIA博途中累计流量的两种计算方法示例
    38 | Linux 磁盘空间异常爆满
    基于STC12C5A60S2系列1T 8051单片的IIC总线器件模数芯片PCF8591实现模数转换应用
  • 原文地址:https://blog.csdn.net/u012868901/article/details/134194843
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号