【MongoDB】TTL时效集合
admin
2023-02-06 11:20:03
0

    TTL索引(time to live index,具有生命周期的索引),这种索引允许为每一个文档设置一个超时时间。一个文档到达预设置的老化程度之后就会被删除。这种类型的索引对于缓存问题(比如会话的保存)非常有用。


    在创建索引的时候,顺便指定expireAfterSeconds选项就可以创建一个TTL索引,该集合也就属于TTL集合了。

// 创建TTL索引, 设置超时时间为24小时
db.ttl.ensureIndex({date:1},{expireAfterSeconds:24*60*60});


    这样就在"date"字段上创建了一个TTL索引。如果一个文档的"date"存在并且它的值是日期类型,当服务器时间比文档的"date"字段的时间晚expireAfterSeconds秒时,文档就会被删除。


    为了防止活跃的会话被删除,可以在会话上有活动发生时将"date"字段更新为当前时间。只要"date"距离当前时间达到24小时,文档就会被删除。


    MongoDB每分钟对TTL索引进行一次清理,所以不应该依赖以秒为单位的时间来保证索引的存活状态。可以使用collMod命令来更改expireAfterSeconds的值:

db.runCommand(
    {
        collMod:"ttl",
        index:{
            keyPattern:{date:1}, 
            expireAfterSeconds:3600
        }
     }
)


    在一个给定的集合上可以有多个TTL索引。TTL索引不能是复合索引,但是可以像普通索引一样用来优化排序和查询。


相关内容

热门资讯

中山企业家担任国际标准化组织要... 近日,国际标准化组织(ISO)官网公布,位于中山火炬高新区的广东欧亚包装有限公司董事长连运增担任国际...
全球首台20兆瓦风机成功过吊装 来源:滚动播报 (来源:千龙网) 1月13日,记者从三峡集团获悉,全球首台20兆瓦海上风电机组在福建...
格陵兰岛,俄方是在说西方人没听... 俄高级官员声称,如果特朗普不尽快采取行动,格陵兰岛可能会投票加入俄罗斯。俄罗斯的战略诱骗在发力。格陵...
闲鱼平台惊现“代坐”服务:二手... 来源:GPLPCN 近日,有网友反映,在闲鱼平台上出现了提供上海地铁“代坐”服务的帖子,标价1.9...
报告:工厂智能化呈现“东高、中... 转自:中国新闻网 报告:工厂智能化呈现“东高、中快、西广”区域格局 中新网北京1月13日电 (记者 ...
胡锡进:特朗普又在试探中国,他... 特朗普周一通过社交媒体发出最新威胁:任何与伊朗进行贸易的国家,其对美贸易都将被征收25%的关税,并且...
以女性视角拓展科幻的边界:可以... 2026年伊始,浙江文艺出版社·KEY-可以文化推出全新科幻书系“越境”。首批上市的《陌生的女孩》与...
原创 向... 如今,提到“芯片被围堵”“发动机被技术封锁”等词汇早已不再是新鲜的概念,对于我们这些从事这行的兄弟姐...
顶级商战往往采用最朴素的方式:... 新智元报道 编辑:倾倾 【新智元导读】马斯克在2025最后一天连夜贴脸开大!自建电厂、暴力圈地,直...
5.1亿美元,美企计划买下柬埔... 美国查尔斯河实验室国际公司1月12日说,为了支持公司研究新药和测试药物安全,他们打算花大约5.1亿美...