node.js - mongo TTL 數(shù)據(jù)過期不刪除
問題描述
使用 mongoose 可以成功為某個(gè) document 添加過期時(shí)間:
但是,數(shù)據(jù)在設(shè)置的過期時(shí)間之后仍然沒有刪除,官方的文檔說mongo后臺服務(wù)每隔一分鐘輪詢一次過期設(shè)置,但這已經(jīng)不是幾分鐘延遲的事了,感覺上是expire沒有生效的
問題解答
回答1:這個(gè)問題我自己解決了,重新看了下官方文檔 https://docs.mongodb.com/manu...
schema定義的索引必須與實(shí)際的數(shù)據(jù)相對應(yīng)。
let myschema = new mongoose.Schema({ phone: {type: String,required: true }, code: {type: String,required: true }, createAt: {type: Date,default: Date.now(),index: { expires: 60*1 } //設(shè)置驗(yàn)證碼的有效時(shí)間為 10 分鐘 }}, {collection: ’sms’} ); let MyModel = db.model(’MyModel’, myschema); let arr = {phone: req.body.phone,code: code,createAt: Date.now() }
schema 中的 createAt 必須與 arr 中的 createAt 對應(yīng),且必須給定時(shí)間,這樣才會(huì)生效。
回答2:let mySchema = new mongoose.Schema(...)試試?
回答3:幾點(diǎn)建議:
1、先檢查一下索引的實(shí)際TTL情況;您貼出來的部分,感覺上面代碼和下面的截圖不一致
2、看看server.Status中的ttl的部分
db.serverStatus().metrics.ttl
供參考。
Love MongoDB!Have fun!
相關(guān)文章:
1. macos - mac 重啟后 XAMPP下的apache無法啟動(dòng)2. css3 - 這個(gè)右下角折角用css怎么畫出來?3. mysql - eclispe無法打開數(shù)據(jù)庫連接4. windows2003下的apache響應(yīng)時(shí)間特別長?5. javascript - 在 model里定義的 引用表模型時(shí),model為undefined。6. 關(guān)于Java引用傳遞的一個(gè)困惑?7. java - 根據(jù)月份查詢多個(gè)表里的內(nèi)容怎么實(shí)現(xiàn)好?8. javascript - 一個(gè)關(guān)于客戶端和前端通信的疑惑?9. php - 一個(gè)操作請求多個(gè)服務(wù)如何保證數(shù)據(jù)的安全?10. javascript - webpack熱加載配置不生效
