MongoDB中存在一種索引,叫做TTL索引(time-to-live index,具有生命周期的索引),這種索引允許為每一個文檔設(shè)置一個超時時間。一個文檔達到預(yù)設(shè)置的老化程度后就會被刪除。
數(shù)據(jù)到期對于某些類型的信息非常有用,例如機器生成的事件數(shù)據(jù),日志和會話信息,這些信息只需要在數(shù)據(jù)庫中保存有限的時間。
在createIndex中指定expireAfterSeconds選項就可以創(chuàng)建一個TTL索引:
// 超時時間為24小時,默認(rèn)是前臺運行,可以通過background:true設(shè)置為后臺模式db.user_session.createIndex({"updated":1},{expireAfterSeconds:60*60*24});
這樣在updated字段上創(chuàng)建了一個TTL索引。如果一個文檔的updated字段存在并且它的值是日期類型,當(dāng)服務(wù)器時間比文檔的updated字段的時間晚expireAfterSeconds秒時,文檔就會被刪除。
db.getCollection('user_session').insert( { _id: NumberInt(1), "updated":new Date(), username:'lisi' });
mongodb保存時間使用的UTC時間,在查詢出來的結(jié)果的時候會轉(zhuǎn)換為GMT時間,所以你看到保存的時間和電腦時間相差8個小時(GMT+8)
db.getCollection('user_session').find({updated:{$gt: new Date("2019-07-12 14:00:00")}}) 在查詢的時候可以使用new Date()直接進行時間的比較,new Date傳入的參數(shù)是GMT時間
為了防止活躍的會話被刪除,可以在會話上有活動發(fā)生時將updated字段的值更新為當(dāng)前時間。只要updated的時間距離當(dāng)前時間達到24小時。相應(yīng)的文檔就會被刪除。
MongoDB的TTL功能依賴于mongodb中的后臺線程,該線程讀取索引中的日期類型值并從集合中刪除過期的文檔。
MongoDB每分鐘對TTL索引進行一次清理,所以不應(yīng)該依賴以秒為單位的時間保證索引的存活狀態(tài)。而且TTL索引不保證在到期時立即刪除過期數(shù)據(jù)。文檔到期的時間與MongoDB從數(shù)據(jù)庫中刪除文檔的時間之間可能存在延遲。由于刪除過期文檔的后臺任務(wù)每60秒運行一次。所以,文檔可能在文檔到期和后臺任務(wù)運行之間的期間保留在集合中。
源碼在 github.com/mongodb/mon…
mongodb不支持使用createIndex來重新設(shè)置過期時間,只可以使用collMod命令修改expireAfterSeconds的值:
db.runCommand({collMod:"user_session",index: {name:"updated_1",expireAfterSeconds: 120}});
修改成功后,你會收到這樣的消息(之前的過期時間是一分鐘,現(xiàn)在修改為2分鐘)
{ "expireAfterSeconds_old" : 60.0, "expireAfterSeconds_new" : 120.0, "ok" : 1.0}
在一個給定的集合上可以有多個TTL索引,你可以在created和updated字段分別建立ttl索引,但是不能同時使用兩個字段建立復(fù)合ttl索引,也不能在同一個字段上又是創(chuàng)建TTL索引,又是創(chuàng)建普通索引,但是可以像“普通索引”一樣用來優(yōu)化排序和查詢。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對武林網(wǎng)的支持。
新聞熱點
疑難解答