MongoDB中的定時索引

think123發表於2019-08-01

MongoDB中存在一種索引,叫做TTL索引(time-to-live index,具有生命週期的索引),這種索引允許為每一個文件設定一個超時時間。一個文件達到預設定的老化程度後就會被刪除。 資料到期對於某些型別的資訊非常有用,例如機器生成的事件資料,日誌和會話資訊,這些資訊只需要在資料庫中儲存有限的時間。

在createIndex中指定expireAfterSeconds選項就可以建立一個TTL索引:

// 超時時間為24小時,預設是前臺執行,可以通過background:true設定為後臺模式
db.user_session.createIndex({"updated":1},{expireAfterSeconds:60*60*24});
複製程式碼

這樣在updated欄位上建立了一個TTL索引。如果一個文件的updated欄位存在並且它的值是日期型別,當伺服器時間比文件的updated欄位的時間晚expireAfterSeconds秒時,文件就會被刪除。

db.getCollection('user_session').insert(
  {
    _id: NumberInt(1),
    "updated":new Date(),
     username:'lisi'
  }
);
複製程式碼

mongodb儲存時間使用的UTC時間,在查詢出來的結果的時候會轉換為GMT時間,所以你看到儲存的時間和電腦時間相差8個小時(GMT+8) db.getCollection('user_session').find({updated:{$gt: new Date("2019-07-12 14:00:00")}}) 在查詢的時候可以使用new Date()直接進行時間的比較,new Date傳入的引數是GMT時間

為了防止活躍的會話被刪除,可以在會話上有活動發生時將updated欄位的值更新為當前時間。只要updated的時間距離當前時間達到24小時。相應的文件就會被刪除。

MongoDB的TTL功能依賴於mongodb中的後臺執行緒,該執行緒讀取索引中的日期型別值並從集合中刪除過期的文件。 MongoDB每分鐘對TTL索引進行一次清理,所以不應該依賴以秒為單位的時間保證索引的存活狀態。而且TTL索引不保證在到期時立即刪除過期資料。文件到期的時間與MongoDB從資料庫中刪除文件的時間之間可能存在延遲。由於刪除過期文件的後臺任務每60秒執行一次。所以,文件可能在文件到期和後臺任務執行之間的期間保留在集合中。

原始碼在 github.com/mongodb/mon…

mongodb不支援使用createIndex來重新設定過期時間,只可以使用collMod命令修改expireAfterSeconds的值:

db.runCommand({collMod:"user_session",index: {name:"updated_1",expireAfterSeconds: 120}});
複製程式碼

修改成功後,你會收到這樣的訊息(之前的過期時間是一分鐘,現在修改為2分鐘)

{
    "expireAfterSeconds_old" : 60.0,
    "expireAfterSeconds_new" : 120.0,
    "ok" : 1.0
}

複製程式碼

在一個給定的集合上可以有多個TTL索引,你可以在created和updated欄位分別建立ttl索引,但是不能同時使用兩個欄位建立複合ttl索引,也不能在同一個欄位上又是建立TTL索引,又是建立普通索引,但是可以像“普通索引”一樣用來優化排序和查詢。

相關文章