在上篇《试着用Node.js重写了抽卡系统》中出现的查看最新动态里,原先在Emlog版里我是用json文件储存并且限制了条数,但是在Node.js版里我将动态数据储存到了MongoDB数据库当中了,于是就出现一个问题。

因为是日志类数据,以后必定会有大量不必要的数据产生,这里就需要对数据量做一个限制,超过限制就要覆盖掉最旧的数据。

这里就要用到capped。

然后查阅官方文档会发现:

new Schema({..}, { capped: 1024 });

new Schema({..}, { capped: { size: 1024, max: 1000, autoIndexId: true } });

两种写法。

这里size为必填,为一个文档的总大小,单位为字节,文档超过这个大小后就会开始覆盖旧数据。

max为文档数量,选填,如果文档超过设定值就会覆盖旧数据,但是如果在超过数量之前先超过了文档的设定大小则也会覆盖旧数据。

autoIndexId为自动创建索引也就是_id,这个设置在我5.4.19版本的Mongoose里会被提示即将废弃。所以如果是用新版的Mongoose的话,这个选项推荐不填。