1. 判断哪些是慢查询?

   mongodb通过profile来实时的获取性能较慢的查询,设置profile命令如下


  db.runCommand { profile: 1, slowms: 200 }

表示开启profile,记录大于200毫秒的操作


profile值有以下含义


-1

无变化,返回当前profile值

0

关闭profile, 这是系统默认的profile值

1

开启,只记录慢的操作

2

开启,记录所有操作

或者使用MongoVUE工具

mongodb查找性能 mongo 查询性能_mongodb


开启后,mongodb会生成system.profile的collection来存储哪些慢的操作

2. 分析慢查询

使用.explain()方法分析查询,例如  db.XXX.find(....).explain()则会生成一个对查询的解释:

   查询结果最主要关注下面几个字段

  • cursor:   BasicCursor 表示用的是非索引的查询, BtreeCursor 表示用的是B树查询,同时会告诉用的是哪个索引
  • nscanned: 
  • nscannedObjects: 总共扫描的documents数量
  • n: 满足条件对象的数量
  • millis: 查询花费的时间(微秒)


一般来讲cursor使用B树查询效率高,如果使用了B树查询仍然慢,则需要根据查询条件和数据特点增加不同的索引,例如增加不同字段的组合索引,使得查询能够优先选择更高效的索引,这个是由mongodb自身内部进行选择的。



参考:

https://docs.mongodb.com/manual/reference/command/profile/