【MongoDB】TTL时效集合
2016-04-09 09:17
441 查看
TTL索引(time to live index,具有生命周期的索引),这种索引允许为每一个文档设置一个超时时间。一个文档到达预设置的老化程度之后就会被删除。这种类型的索引对于缓存问题(比如会话的保存)非常有用。
在创建索引的时候,顺便指定expireAfterSeconds选项就可以创建一个TTL索引,该集合也就属于TTL集合了。
这样就在"date"字段上创建了一个TTL索引。如果一个文档的"date"存在并且它的值是日期类型,当服务器时间比文档的"date"字段的时间晚expireAfterSeconds秒时,文档就会被删除。
为了防止活跃的会话被删除,可以在会话上有活动发生时将"date"字段更新为当前时间。只要"date"距离当前时间达到24小时,文档就会被删除。
MongoDB每分钟对TTL索引进行一次清理,所以不应该依赖以秒为单位的时间来保证索引的存活状态。可以使用collMod命令来更改expireAfterSeconds的值:
在一个给定的集合上可以有多个TTL索引。TTL索引不能是复合索引,但是可以像普通索引一样用来优化排序和查询。
本文出自 “DeaconLi” 博客,请务必保留此出处http://lizhuquan0769.blog.51cto.com/2591147/1761983
在创建索引的时候,顺便指定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索引不能是复合索引,但是可以像普通索引一样用来优化排序和查询。
本文出自 “DeaconLi” 博客,请务必保留此出处http://lizhuquan0769.blog.51cto.com/2591147/1761983
相关文章推荐
- MongoDB图形化管理工具
- MongoDB常用操作命令大全
- 5、mongodb文档的查找操作
- 4、MongoDB集合里面文档的插入,查找,更新操作
- 3、MongoDB数据库集合常用操作
- 2、mongodb关于数据库的操作
- Linux下自动备份Mongodb数据库并删除指定天数前的备份
- ES-MongoDB学习错误1_Could not import mongo_connector.doc_managers.elastic_doc_manager
- MongoDB:逐渐变得无关紧要
- mongodb数据库备份
- 【MongoDB】mongoimport and mongoexport of data (一)
- SpringMVC+ibatis+MySQL+MongoDB构建博客系统(二)
- MongoDB常用命令合集
- MongoDB学习 (六):查询
- SpringMVC+ibatis+MySQL+MongoDB构建博客系统(一)
- Springmvc + mongodb + js 分页显示数据
- MongoDB Java驱动快速上手
- 1、MongoDB的安装
- linux下安装mongodb3.2.4
- 第一章 安装MongoDB