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