時(shí)間:2024-03-26 14:42作者:下載吧人氣:37
Mongodb通常會(huì)被用來(lái)存儲(chǔ)緩存數(shù)據(jù)或大尺寸、低價(jià)值的數(shù)據(jù),對(duì)于這些類(lèi)型的數(shù)據(jù),數(shù)據(jù)量往往非常大,如果不定期清理,不但會(huì)影響性能,也會(huì)浪費(fèi)大量的系統(tǒng)資源。
Mongodb其實(shí)可以像Redis一樣設(shè)置數(shù)據(jù)的過(guò)期時(shí)間,TTL索引是MongoDB中一種特殊的索引,可以支持文檔在一定時(shí)間之后自動(dòng)過(guò)期刪除,目前TTL索引只能在單字段上建立。
當(dāng)你在集合中某一個(gè)字段建立TTL索引后,后臺(tái)會(huì)有一個(gè)單線程,通過(guò)不斷查詢(xún)(默認(rèn)60s一次)索引的值來(lái)判斷document是否有過(guò)期,并且刪除文檔的動(dòng)作還依據(jù)mongod實(shí)例的負(fù)載情況,如果負(fù)載很高,可能會(huì)稍微延后一段時(shí)間再刪除。
創(chuàng)建TTL索引方法:
和普通索引的創(chuàng)建方法一樣,只是會(huì)多加一個(gè)屬性而已
例:在log_events的集合中,createTime 字段上建立一小時(shí)后過(guò)期的TTL索引
db.log_events.createIndex( { “createTime”: 1 }, —字段名稱(chēng)
{ expireAfterSeconds: 60*60 } ) —過(guò)期時(shí)間(單位秒)
網(wǎng)友評(píng)論