Mongodb(使用mongoose)expiresAfterSeconds(TTL)似乎不起作用

时间:2013-06-12 17:46:43

标签: node.js mongodb mongoose

我正在使用猫鼬。

我的架构是这样的:

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

1 个答案:

答案 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”。