我正在使用猫鼬。
我的架构是这样的:
var UsuarioSchema = new Schema({
email : { type : Email, index : { unique : true}, required : true },
//some other fields, but not required, hopefully, for this sample code
test_expira : { type : Date, default : Date.now, index : { expires : 120 }}
});
在mongodb shell上运行时,这是我认为重要的信息:
> db.usuarios.getIndexes()
[
{
"v" : 1,
"key" : {
"_id" : 1
},
"ns" : "dbnamehere.usuarios",
"name" : "_id_"
},
{
"v" : 1,
"key" : {
"email" : 1
},
"unique" : true,
"ns" : "dbnamehere.usuarios",
"name" : "email_1",
"background" : true,
"safe" : true
},
{
"v" : 1,
"key" : {
"test_expira" : 1
},
"ns" : "dbnamehere.usuarios",
"name" : "test_expira_1",
"expiresAfterSeconds" : 120,
"background" : true,
"safe" : true
}
]
> new Date();
ISODate("2013-06-12T17:41:43.263Z")
> db.usuarios.findOne({email : 'someemail@gmail.com'});
{
/* some fields go in here! */
"email" : "someemail@gmail.com",
/* some more fields go in here */
"_id" : ObjectId("51b8b087de01a2ec28000002"),
"test_expira" : ISODate("2013-06-12T17:31:51.156Z"),
/* some yet more fields go in here */
"__v" : 0
}
我还没有测试过多长时间而没有被删除,但即使是文档只表示一分钟的开销应该是人们可以期待的,但是对于一个应该只持续120秒的文档不会超过15分钟。
我不确定如何处理这个问题。非常感谢帮助:)
编辑: 正在使用的mongodb版本是v2.4.4 mongoose的版本是3.0.3
答案 0 :(得分:2)
我已经测试了这个功能,它适用于2.4.4 MongoDB。
仔细看看你的索引后,我意识到这个问题很小。
我的TTL索引有效:
{
"v" : 1,
"key" : {
"test_expira" : 1
},
"ns" : "test.usuarios",
"name" : "test_expira_1",
"expireAfterSeconds" : 120,
"background" : true,
"safe" : true
}
您的TTL索引不起作用:
{
"v" : 1,
"key" : {
"test_expira" : 1
},
"ns" : "dbnamehere.usuarios",
"name" : "test_expira_1",
"expiresAfterSeconds" : 120,
"background" : true,
"safe" : true
}
请注意,TTL索引的正确密钥名称为“expireAfterSeconds”,其中您的附加字母为“expiresAfterSeconds”。