node.js - mongo TTL 數據過期不刪除
問題描述
使用 mongoose 可以成功為某個 document 添加過期時間:
但是,數據在設置的過期時間之后仍然沒有刪除,官方的文檔說mongo后臺服務每隔一分鐘輪詢一次過期設置,但這已經不是幾分鐘延遲的事了,感覺上是expire沒有生效的
問題解答
回答1:這個問題我自己解決了,重新看了下官方文檔 https://docs.mongodb.com/manu...
schema定義的索引必須與實際的數據相對應。
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 } //設置驗證碼的有效時間為 10 分鐘 }}, {collection: ’sms’} ); let MyModel = db.model(’MyModel’, myschema); let arr = {phone: req.body.phone,code: code,createAt: Date.now() }
schema 中的 createAt 必須與 arr 中的 createAt 對應,且必須給定時間,這樣才會生效。
回答2:let mySchema = new mongoose.Schema(...)試試?
回答3:幾點建議:
1、先檢查一下索引的實際TTL情況;您貼出來的部分,感覺上面代碼和下面的截圖不一致
2、看看server.Status中的ttl的部分
db.serverStatus().metrics.ttl
供參考。
Love MongoDB!Have fun!
相關文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
