问题描述:
开发过程中,手动drop一个collection,由于程序在写入该collection前做了EnsureIndex,等写入了文档之后,在console里调用getIndexes()查看index,居然没有发现预期的索引。
原因:
track进EnsureIndex函数,发现了原因,就是它会首先检查缓存的index
func (c *Collection) EnsureIndex(index Index) error {
keyInfo, err := parseIndexKey(index.Key)
if err != nil {
return err
}
session := c.Database.Session
cacheKey := c.FullName + "\x00" + keyInfo.name
if session.cluster().HasCachedIndex(cacheKey) {
return nil
}
//省略部分代码
}
HasCachedIndex是用来判断该Index是否在出现在缓存中,如果已经出现过,就会忽略掉该操作。因为我在drop掉一个collection之后没有重新启动程序,所以在做EnsureIndex操作的时候直接返回了,相当于失效。
解决方法:
重启我的应用即可看到ensureindex生效了。这是mgo的一个特性,特此记录下来。