1、固定集合
    MongoDB可以创建固定长度的集合,可以设置最大的集合空间或最大的集合数。创建集合的语法如下:
    db.createCollection("collection-name", { option对象 }); # option都为可选对象,可选项如下:
可选参数
   类型
   说明
  capped
   boolean
   默认为false则为正常的集合,当设置为true时,则为固定长度集合,到达设置的空间或集合长度的上线,则会删除最老的数据
  
   autoIndexId
   
   boolean
   为true则在_id上自动创建索引。默认为true,为唯一索引,建立后就不能进行删除索引
  size
   
   数字(单位字节)
   
   前提是capped设置为true。指定集合能使用的数据空间上限。
  max
   
   数字(文档数)
   
   前提是capped设置为true。指定集合能使用的最大文档数据。当文档空间和最大文档数时,谁先到达限制都会触发,而扔掉最老的文档
       db.createCollection("user-max",{capped:true,size:1000000,max:10000,autoIndexId:true});
 
 
 
固定集合特点:
    1、到达数据空间或者文档数的上限,则扔掉最老的文档
    2、MySQL的数据copy使用的是binlog,而MongoDB数据copy则使用固定长度的集合
    3、固定集合不能转换为正常的集合,正常的集合可以转化为固定集合,转化方式如下:
        db.runCommand({"covertToCapped":"collection-name", size:100000,max:1000});
 
 
2、TTL索引
    使用固定集合的方式,不能确认会将哪些数据扔掉。很多时候我们需要保存一段时候的数据,如前面提到的MongoDB应用中的使用--删除旧数据场景。就可以在集合中根据每个文档定时删除不需要的文档,若需要保存数据,则可以让大数据定时将数据抽取走。为集合的创建日期设置一个TTL索引,如下:
      # 保存最近三个月的文档(单位秒),当中途修改了createdAt的值时,则不会删除文档(指定的时间是字段与当前时间的差值)
    db.user.createIndex({"createdAt": 1},{expireAfterSeconds: 60*60*24*3});
 
    # 若需求变动,需要将三个月修改为一个月可以使用collMod,如下:
  db.runCommand({collMod: 'user', index: {keyPattern:{"createdAt": 1}, expireAfterSeconds:60*60*24*1}});
 
  TTL集合特点:
    1、TTL索引是单字段索引,不能使用在聚合索引上
    2、_id主键上不能建立TTL索引
    3、一个集合上可以建立多个TTL索引
    4、不能在普通索引上再创建TTL索引,只能删除再建
    5、TTL索引可以用于普通索引一样进行排序和查询
    6、TTL索引会每分钟检查超时文档,并进行删除操作。需要注意删除时候的并发问题(不要影响线上业务)。

原文链接:https://blog.csdn.net/it_lihongmin/article/details/81739988

MongoDB TTL集合与固定集合的更多相关文章

  1. 【Mongodb】聚合查询 && 固定集合

    概述 数据存储是为了可查询,统计.若数据只需存储,不需要查询,这种数据也没有多大价值 本篇介绍Mongodb 聚合查询(Aggregation) 固定集合(Capped Collections) 准备 ...

  2. MongoDB的学习和使用(固定集合[Capped Collections])

    MongoDB 固定集合(Capped Collections) MongoDB 固定集合(Capped Collections)是性能出色且有着固定大小的集合,对于大小固定,我们可以想象其就像一个环 ...

  3. mongodb的固定集合(优化效率)

    mongodb固定集合(Capped Collection)和大文件管理(GridFS)   Capped Collection   固定集合(Capped Collection)是性能出色的有着固定 ...

  4. MongoDB固定集合(Capped Collections)

    MongoDB 固定集合(Capped Collections)是性能出色且有着固定大小的集合,对于大小固定,我们可以想象其就像一个环形队列,当集合空间用完后,再插入的元素就会覆盖最初始的头部的元素! ...

  5. MongoDB 固定集合

    MongoDB 固定集合(Capped Collections)是性能出色且有着固定大小的集合,对于大小固定,我们可以想象其就像一个环形队列,当集合空间用完后,再插入的元素就会覆盖最初始的头部的元素! ...

  6. 关于MongoDB 固定集合(capped collection)的知识梳理

    一 . 什么是固定集合 MongoDB中有一种特殊类型的集合,值得我们特别留意,那就是固定集合(capped collection). 固定集合可以声明collection的容量大小,其行为类似于循环 ...

  7. mongo 固定集合,大文件存储,简单优化 + 三招解决MongoDB的磁盘IO问题

    1.固定集合 > db.createCollection(, max:});//固定集合 必须 显式创建. 设置capped为true, 集合总大小xxx字节, [集合中json个数max] { ...

  8. MongoDB固定集合(capped collection)

    一 . 什么是固定集合 MongoDB中有一种特殊类型的集合,值得我们特别留意,那就是固定集合(capped collection). 固定集合可以声明collection的容量大小,其行为类似于循环 ...

  9. MongoDB的固定集合

    一.MongoDB固定集合概念 固定集合指的是事先创建,并且大小固定的集合.即假设一个集合设置了固定大小为100,再添加一条文档的时候,会把最前面的文档剔除,永远只保留100条数据. 固定集合特性:固 ...

随机推荐

  1. Django框架之第八篇(模型层补充)--数据库的查询与优化:only/defer,select_related与prefetch_related,事务

    在设置外键字段时需要注意: 当你使用django2.x的版本时候,在建立外键关系时,需要你手动添加几个关键点参数 models.cascade #设置级联删除 db_constraints 数据库查询 ...

  2. Spring-Cloud之Zuul路由网关-6

    一.为什么需要Zuul? Zuul 作为微服务系统的网关组件,用于构建边界服务( Edge Service ),致力于动态路由.过滤.监控.弹性伸缩和安全.Zuul 作为路由网关组件,在微服务架构中有 ...

  3. Java之路---Day07

    2019-10-21-23:30:24 ArrayList类[集合] What:java.util.ArrayList是大小可变的数组的实现,存储在内的数据称为元元素,此类提供一些方法来操作内部存储的 ...

  4. vue页面跳转拦截器

    登录拦截逻辑 第一步:路由拦截 首先在定义路由的时候就需要多添加一个自定义字段requireAuth,用于判断该路由的访问是否需要登录.如果用户已经登录,则顺利进入路由, 否则就进入登录页面.在路由管 ...

  5. JavaScript之轮播图

    (1)html <div class="box" id="box"> <ul class="uls" id="u ...

  6. Java 之 Servlet的urlPartten

    Servlet 的 urlpartten urlpartten:Servlet 访问路径 1.一个 Servlet 可以定义多个访问路径,在使用@WebServlet注解时,可以发现里面的 urlpa ...

  7. 1519484 - How to analyze network disconnections shown in system log (transaction SM21)

    Symptom System log (transaction SM21) shows network disconnections, e.g.: Q04 Connection to user 264 ...

  8. Jmeter学习笔记(十七)——jmeter目录结构

    原文链接:http://www.cnblogs.com/zichuan/p/6938772.html 一.bin目录examples:  目录中有CSV样例 jmeter.bat  windows的启 ...

  9. 【Python】异常

    捕获异常 try: num = int(input("请输入一个整数:")) result = 8 / num print(result) except ValueError: p ...

  10. 计算地图上两点间的距离PHP类

    计算地图上两点间的距离,使用的是谷歌地图 <?php class GeoHelper { /** * @param int $lat1 * @param int $lon1 * @param i ...