Mongoose不会创建TTL索引
这是我的Mongoose模型:
var sessionSchema = new Schema({
_id: { type: String, required: true, index: { unique: true } },
user: { type: Schema.Types.ObjectId },
expire: { type: Date, index: { expireAfterSeconds: 21600 } }
})
module.exports = mongoose.model('Session', sessionSchema)
我需要能够将日期对象设置为过期(通常它类似于Date.now
加上几分钟),并在过期6小时后将对象从集合中移除。
但是,我无法让Mongoose创建索引。 当我在mongo控制台中运行db.sessions.getIndexes()
时,输出如下:
[
{
"v" : 1,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "dev.sessions"
}
]
我也尝试过不同的语法,比如
expire: { type: Date, expires: 21600 }
(Mongoose的简短版本)。
我也尝试在模式级别定义索引:
sessionSchema.index({ expire: 1 }, { expireAfterSeconds: 21600 })
没有任何工作。
与其他人就SO提出问题不同,我的索引根本就没有创建。 我也尝试删除集合和数据库,当它们被重新创建时,它们仍然不包含索引。
版本:Mongoose 3.8.19,MongoDB 2.6.5(OSX)和Node.js 0.10.33
编辑
更多信息:我试图直接从mongo控制台创建索引,其中:
db.sessions.ensureIndex({"expire":1}, {expireAfterSeconds: 21600})
这似乎工作(索引创建)。
但是,它不以任何方式与Mongoose合作。
显然问题是我在自定义_id
字段上创建了一个索引。 MongoDB自己在该字段上创建一个索引,所以当Mongoose调用ensureIndex
来创建TTL索引时,两者都失败。
请参阅https://github.com/LearnBoost/mongoose/issues/2459
链接地址: http://www.djcxy.com/p/82445.html