我屮艸芔茻,mongo居然可以自动删除数据
生活随笔
收集整理的這篇文章主要介紹了
我屮艸芔茻,mongo居然可以自动删除数据
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
1、需求
? ? ? ? 最近在接入其他部門的數(shù)據(jù),但是因為數(shù)據(jù)量太大,所以導(dǎo)致mongo中的數(shù)據(jù)暴漲,所以需要定期刪除數(shù)據(jù)。
2、方案
- 方案1: 在機器上創(chuàng)建cron 定時任務(wù),刪除數(shù)據(jù),
缺點:放在機器上不好管理
- 方案2: 在程序中起一個定時器刪除數(shù)據(jù)
缺點:需要自己調(diào)job,然后還需要拉取所有的數(shù)據(jù)進(jìn)行讀取計算
- ?方案3:使用mongodb 自帶的TTL過期功能,毫無疑問,選擇這個
3、Mongo TTL功能
1、功能實現(xiàn)
2、舉個例子
創(chuàng)建索引
db.log_events.createIndex( { "createdAt": 1 }, { expireAfterSeconds: 3600 } )插入數(shù)據(jù)
db.log_events.insert( {"createdAt": new Date(),"logEvent": 2,"logMessage": "Success!" } )3、原理解析
mongo也沒有什么魔法,下面一起看下
1.可以看到mongo在date字段上創(chuàng)建了索引,這樣在操作刪除的時候只要讀取索引數(shù)據(jù)就可以判斷了
2.索引的過期時間是秒,也就是說在創(chuàng)建的索引上增加過期時間,如果超過當(dāng)前時間就會刪除,這個符合邏輯,也是這么做的,合理
3.mongo 在后臺啟動了一個線程,在后臺線程中讀取索引中的值并從集合中刪除過期的數(shù)據(jù)
4.后臺線程每60s運行一次,所以數(shù)據(jù)不會立即刪除
4、注意點
總結(jié)
在開始的時候還是走了一些彎路,主要是不知道要在date字段上建立索引,并且不知道60s 的運行間隔,導(dǎo)致研究了老半天,就是看不到數(shù)據(jù)刪除。
不過不重要,也算是學(xué)習(xí)了
?
總結(jié)
以上是生活随笔為你收集整理的我屮艸芔茻,mongo居然可以自动删除数据的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: WIN10下Apache启动失败
- 下一篇: 【VS开发】MP4与H.264