MongoDB TTL索引的实例详解
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,MongoDB TTL索引的实例详解TTL索引是一种特殊类型的单字段索引,主要用于当满足某个特定时间之后自动删除相应的文档。也就是说集合中的文档有一定的有效期,超过有效期的文档就会失效,会被移除。也即
千家信息网最后更新 2025年01月23日MongoDB TTL索引的实例详解
MongoDB TTL索引的实例详解
TTL索引是一种特殊类型的单字段索引,主要用于当满足某个特定时间之后自动删除相应的文档。也就是说集合中的文档有一定的有效期,超过有效期的文档就会失效,会被移除。也即是数据会过期。过期的数据无需保留,这种情形适用于如机器生成的事件数据,日志和会话信息等等。本文主要描述TTL索引的使用。
一、TTL索引
创建方法 db.collection.createIndex(keys, options) options: expireAfterSeconds 指定多少秒或者包含日期值的数组创建示例 db.eventlog.createIndex( { "lastModifiedDate": 1 }, { expireAfterSeconds: 3600 } ) 何时失效 在指定的时间达到后失效,也即是索引字段的值加上一个特定的秒数之后 如果索引字段是一个数组,即索引字段上存在着多个日期值,此时MongoDB取最小值加上失效时间(lowest()) 对于非日期字段或不包含日期数组的索引字段,文档不会失效 对于不包含索引字段的文档,文档不会失效删除操作 mongod的一个后台线程会读取索引的值并将失效的文档从集合移除 当TTL线程被激活后,可以从db.currentOp()或者从profile观察到删除操作何时删除 当基于后台方式创建索引时,TTL线程能够在索引创建期间开始删除失效文档 当基于前台方式创建索引时,TTL线程在索引创建完成后开始删除失效文档 TTL索引的删除不能完全保证失效期后一定删除,存在一定延迟(取决于mongod的工作负载) TTL删除文档后台线程每60s移除失效文档(因此可能存在已过失效期,文档还在的情形) 在副本集环境中,TTL后台线程仅仅在主副本上工作,辅助副本上由复制操作实现 在使用TTL索引查询时,与使用非TTL索引一样一些限制 不能基于已经存在索引的字段创建TTL索引以及非日期字段创建TTL索引,文档不会失效 TTL索引不支持基于多个字段的复合索引 不支持定长集合
二、TTL索引示例
# mongo --shell localhost:27000 TTLData.js MongoDB shell version: 3.2.11connecting to: localhost:27000/testrepSetTest:PRIMARY> addTTLTestData() //添加集合数据Create three records in database each with a create time that is 1 minute apartCreated three test documents, oldest being 4 mins oldNow create a TTL index with expiry of 5 mins on the createDate field as followsdb.ttlTest.ensureIndex({createDate:1}, {expireAfterSeconds:300})repSetTest:PRIMARY> db.ttlTest.find() //当前向集合里插入了3个文档{ "_id" : 1, "createDate" : ISODate("2017-03-10T03:23:01.169Z") }{ "_id" : 2, "createDate" : ISODate("2017-03-10T03:24:01.169Z") }{ "_id" : 3, "createDate" : ISODate("2017-03-10T03:25:01.169Z") }//下面为测试集合上的文档添加索引,即5分钟后索引失效repSetTest:PRIMARY> db.ttlTest.createIndex({createDate:1}, {expireAfterSeconds:300}){ "createdCollectionAutomatically" : false, "numIndexesBefore" : 1, // Author : Leshami "numIndexesAfter" : 2, // Blog : http://blog.csdn.net/leshami "ok" : 1}//查找文档repSetTest:PRIMARY> db.ttlTest.find(){ "_id" : 1, "createDate" : ISODate("2017-03-10T03:23:01.169Z") }{ "_id" : 2, "createDate" : ISODate("2017-03-10T03:24:01.169Z") }{ "_id" : 3, "createDate" : ISODate("2017-03-10T03:25:01.169Z") }//当指定时间到期后,文档被删除,如下,查询不到任何文档repSetTest:PRIMARY> db.ttlTest.find()
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
索引
文档
字段
线程
日期
后台
数据
时间
副本
数组
支持
有效
多个
情形
效期
方式
有效期
示例
工作
查询
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
公安网网络安全培训心得体会
公众号软件开发服务费用
江苏地区服务器云空间
什么程序可以导入数据库文件
黑色沙漠季节服务器时间
福建厦门dns服务器地址
成都哪个软件开发靠谱
北京交通大学数据库系统考试
计算机网络技术主修科目
spss读取mdb数据库
芜湖智联网络技术有限公司
网络安全生产教育培训河北
金融服务器管理系统
东阳市吴宁海宸网络技术服务部
沈阳软件开发日语
我的世界服务器给人管理
山东安全接入服务器地址
快家网络技术有限公司怎么样
一台服务器几个容器
enricher数据库
注册怎么把值存数据库
网络安全的最基本属性CIA
计算机软件开发与应用
起亚uvo无法连接服务器
网络安全与加密
万州网络安全宣传周
软件开发java工资待遇
创建sql数据库添加数据库
网络安全意识调查表
node.js 云服务器