a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁(yè) > 數(shù)據(jù)庫(kù) > MongoDB > 正文

MongoDB TTL索引的實(shí)例詳解

2020-03-14 12:51:31
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

MongoDB TTL索引的實(shí)例詳解

TTL索引是一種特殊類(lèi)型的單字段索引,主要用于當(dāng)滿(mǎn)足某個(gè)特定時(shí)間之后自動(dòng)刪除相應(yīng)的文檔。也就是說(shuō)集合中的文檔有一定的有效期,超過(guò)有效期的文檔就會(huì)失效,會(huì)被移除。也即是數(shù)據(jù)會(huì)過(guò)期。過(guò)期的數(shù)據(jù)無(wú)需保留,這種情形適用于如機(jī)器生成的事件數(shù)據(jù),日志和會(huì)話(huà)信息等等。本文主要描述TTL索引的使用。

一、TTL索引

創(chuàng)建方法    db.collection.createIndex(keys, options)    options:        expireAfterSeconds 指定多少秒或者包含日期值的數(shù)組創(chuàng)建示例    db.eventlog.createIndex( { "lastModifiedDate": 1 }, { expireAfterSeconds: 3600 } ) 何時(shí)失效    在指定的時(shí)間達(dá)到后失效,也即是索引字段的值加上一個(gè)特定的秒數(shù)之后    如果索引字段是一個(gè)數(shù)組,即索引字段上存在著多個(gè)日期值,此時(shí)MongoDB取最小值加上失效時(shí)間(lowest())    對(duì)于非日期字段或不包含日期數(shù)組的索引字段,文檔不會(huì)失效    對(duì)于不包含索引字段的文檔,文檔不會(huì)失效刪除操作    mongod的一個(gè)后臺(tái)線(xiàn)程會(huì)讀取索引的值并將失效的文檔從集合移除    當(dāng)TTL線(xiàn)程被激活后,可以從db.currentOp()或者從profile觀(guān)察到刪除操作何時(shí)刪除    當(dāng)基于后臺(tái)方式創(chuàng)建索引時(shí),TTL線(xiàn)程能夠在索引創(chuàng)建期間開(kāi)始刪除失效文檔    當(dāng)基于前臺(tái)方式創(chuàng)建索引時(shí),TTL線(xiàn)程在索引創(chuàng)建完成后開(kāi)始刪除失效文檔       TTL索引的刪除不能完全保證失效期后一定刪除,存在一定延遲(取決于mongod的工作負(fù)載)    TTL刪除文檔后臺(tái)線(xiàn)程每60s移除失效文檔(因此可能存在已過(guò)失效期,文檔還在的情形)    在副本集環(huán)境中,TTL后臺(tái)線(xiàn)程僅僅在主副本上工作,輔助副本上由復(fù)制操作實(shí)現(xiàn)    在使用TTL索引查詢(xún)時(shí),與使用非TTL索引一樣一些限制    不能基于已經(jīng)存在索引的字段創(chuàng)建TTL索引以及非日期字段創(chuàng)建TTL索引,文檔不會(huì)失效    TTL索引不支持基于多個(gè)字段的復(fù)合索引    不支持定長(zhǎng)集合

二、TTL索引示例

# mongo --shell localhost:27000 TTLData.js MongoDB shell version: 3.2.11connecting to: localhost:27000/testrepSetTest:PRIMARY> addTTLTestData() //添加集合數(shù)據(jù)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()  //當(dāng)前向集合里插入了3個(gè)文檔{ "_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") }//下面為測(cè)試集合上的文檔添加索引,即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") }//當(dāng)指定時(shí)間到期后,文檔被刪除,如下,查詢(xún)不到任何文檔repSetTest:PRIMARY> db.ttlTest.find()

如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MongoDB頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久久网址 | 亚洲区一区二 | 国产精品一区二区免费看 | 一级看片| 性色av一区二区三区 | 免费在线看a | 久久久久久久av | 日本免费在线观看 | 日韩91精品 | 欧美精品福利视频 | 国产综合区 | 国产成人啪午夜精品网站男同 | 久久久精品国产 | 国产 在线 | 日韩 | 爱爱视频免费在线观看 | 精品一区二区三区在线观看 | 99精品一区 | 亚洲涩涩涩 | 91.成人天堂一区 | 国产成人精品午夜视频' | 久久国产一区二区三区 | 自拍偷拍小视频 | 国产精品视频网 | 久久91精品国产91久久跳 | 欧洲毛片| 国产精品99一区二区三区 | 国产欧美久久一区二区三区 | 国产免费黄色 | 国产精品久久久久久久久免费丝袜 | 麻豆免费短视频 | 久久久久久免费毛片精品 | 精品无人乱码一区二区三区 | 日韩极品视频 | 好大好爽快点深一点陶软 | 亚洲精品一区二区三区在线 | 国产美女精品人人做人人爽 | 精品成人一区 | 99re在线| 日韩精品一区二区三区中文字幕 | 成人精品一区二区三区中文字幕 | 成人免费视频一区 |