MySQLMongo Database 性能优化

SQL Server有工具举办数据库的优化,Mongo Database
Profiler.不仅有,而且效果更有力。

MongoDB 自带
Profiler,能够充足有利于地记录下具有耗时过长操作,以便于调优。有二种情势可以控制
Profiling 的开关和级别,第一种是一贯在启动参数里一向开展安装。

启动MongoDB时加上–profile=级别 即可。

也得以在客户端调用db.setProfilingLevel(级别)
命令来实时配置。可以透过db.getProfilingLevel()命令来拿到当前的Profile级别。

1

2

3

> db.setProfilingLevel(2);

{"was" : 0 , "ok" : 1}

> db.getProfilingLevel()

上边斜体的级别可以取0,1,2 六个值,他们意味着的意义如下:

0 –
不打开,关闭性能分析,测试环境可以打开,生成环境关闭,对性能有很大影响

1 – 记录慢命令 (默认为>100ms)

2 – 记录所有命令

Profile
记录在级别1时会记录慢命令,那么那么些慢的定义是咋样?上边咱们说到其默认为100ms,当然有默认就有设置,其安装方法和级别相同有二种,一种是经过丰硕–slowms启动参数配置。第两种是调用db.setProfilingLevel时加上第二个参数:

1

2

db.setProfilingLevel( level , slowms )

db.setProfilingLevel( 1 , 10 );

Profiler 音信保存在 system.profile (Capped Collection) 中。也得以由此那么些工具举行设置和查看数据:强硬的MongoDB数据库管理工具

Mongo Shell 还提供了一个相比短小的指令show
profile,可列出如今5条实施时间超过1ms的 Profile 记录。

翻开当前库下所有集合的解析数据

db.system.profile.find()
查阅某一个会聚的辨析数据

db.system.profile.find({info:/user.info/})
翻开执行时间大于100飞秒的履行操作,并倒序排列,并取前5行

db.system.profile.find({millis:{$gt:100}}).sort({$natural:-1}).limit(5);

Profile 信息内容详解:

ts-该命令在什么时候执行.

millis 提姆(Tim)e-该命令执行耗时,以皮秒记.

info-本命令的详尽信息.

query-表明这是一个query查询操作.

ntoreturn-本次查询客户端要求回到的笔录数.比如, findOne()命令执行时
ntoreturn 为 1.有limit(n) 条件时ntoreturn为n.

query-具体的询问条件(如x>3).

nscanned-这一次查询扫描的笔录数.

reslen-重回结果集的大小.

nreturned-本次查询实际再次来到的结果集.

update-申明这是一个update更新操作.

fastmod-Indicates a fast modify operation. See
Updates. These
operations are normally quite fast.

fastmodinsert – indicates a fast modify operation that performed an
upsert.

upsert-讲明update的upsert参数为true.此参数的法力是一旦update的笔录不设有,则用update的口径insert一条记录.

moved-表明此次update是否移动了硬盘上的数额,倘诺新记录比原记录短,平日不会活动当前记录,假诺新记录比原记录长,那么可能会活动记录到任何地点,那时候会造成相关索引的更新.磁盘操作更多,加上索引更新,会使得那样的操作相比慢.

insert-这是一个insert插入操作.
getmore-这是一个getmore
操作,getmore通常暴发在结果集比较大的询问时,第一个query重临了有的结果,后续的结果是通过getmore来得到的。

2、优化

MongoDB 查询优化

假使nscanned(扫描的记录数)远大于nreturned(再次来到结果的记录数)的话,那么大家即将考虑通过加索引来优化记录定位了。

reslen
如果过大,那么申明我们回去的结果集太大了,这时请查看find函数的第二个参数是否只写上了你需要的属性名。(类似于MySQL中并非老是select
*)

对于开创索引的提出是:假诺很少读,那么尽量不要添加索引,因为索引越多,写操作会越慢。假使读量很大,那么创设索引仍然相比较经济的。

MongoDB 更新优化

假定写查询量或者update量过大的话,多加索引是会有裨益的。以及~~~~(省略N字,和RDBMS差不多的道理)

Use fast modify operations when possible (and usually with these, an
index). See Updates.

Profiler 的效率

Profiling
功用肯定是会潜移默化功效的,不过不太严重,原因是她采取的是system.profile
来记录,而system.profile 是一个capped
collection

这种collection 在操作上有一些范围和特色,然而效用更高。

优化提出:

  • 假使 nscanned 远大于 nreturned,那么需要运用索引。
  • 假诺 reslen 重返字节非常大,那么考虑只得到所需的字段。
  • 实施 update 操作时一样检查一下
    nscanned,并使用索引减弱文档扫描数量。
  • 利用 db.eval() 在服务端执行某些总括操作。
  • 压缩重回文档数量,使用 skip & limit 分页。
网站地图xml地图