zoukankan      html  css  js  c++  java
  • mongodb定时删除数据(索引删除)

    一 简介:本文介绍创建自动删除数据的TTL索引

    二 目的 定时删除数据
    三 创建方法
       db.collection.createIndex(keys, options)
       options:
       expireAfterSeconds 指定多少秒或者包含日期值的数组

       创建示例
       db.eventlog.createIndex( { "lastModifiedDate": 1 }, { expireAfterSeconds: 3600 },{backgroup: true})

    四 何时失效
       1 在指定的时间达到后失效,也即是索引字段的值加上一个特定的秒数之后
       2 如果索引字段是一个数组,即索引字段上存在着多个日期值,此时MongoDB取最小值加上失效时间(lowest())
       3  对于非日期字段或不包含日期数组的索引字段,文档不会失效
       4  对于不包含索引字段的文档,文档不会失效

    五 删除操作
       1 mongod的一个后台线程会读取索引的值并将失效的文档从集合移除
       2 当TTL线程被激活后,可以从db.currentOp()或者从profile观察到删除操作

    六 何时删除
       1 当基于后台方式创建索引时,TTL线程能够在索引创建期间开始删除失效文档
       2 当基于前台方式创建索引时,TTL线程在索引创建完成后开始删除失效文档 
       3 TTL索引的删除不能完全保证失效期后一定删除,存在一定延迟(取决于mongod的工作负载)
       4 TTL删除文档后台线程每60s移除失效文档(因此可能存在已过失效期,文档还在的情形)
       5  在副本集环境中,TTL后台线程仅仅在主副本上工作,辅助副本上由复制操作实现
       6  在使用TTL索引查询时,与使用非TTL索引一样

    七 一些限制
       1 不能基于已经存在索引的字段创建TTL索引以及非日期字段创建TTL索引,文档不会失效
       2 TTL索引不支持基于多个字段的复合索引
       3 不支持定长集合
    本文系转载文章来源 https://blog.csdn.net/leshami/article/details/61195427

  • 相关阅读:
    匈牙利算法(二分图匹配)
    匈牙利算法(二分图匹配)
    Redis 笔记与总结6 Redis 高级应用之 事务处理、持久化操作、pub_sub、虚拟内存
    大数据的五大误区及其破解之道
    大数据的五大误区及其破解之道
    统计之 - 协方差_数据分析师
    统计之 - 协方差_数据分析师
    数据挖掘之七种常用的方法_数据分析师
    数据挖掘之七种常用的方法_数据分析师
    方差分析一般线性模型
  • 原文地址:https://www.cnblogs.com/xwjBlog/p/11059299.html
Copyright © 2011-2022 走看看