MongoDB 的日志系统

MongoDB拥有几种日志,分别是系统日志、Journal日志、oplog主从日志、慢查询日志。这些日志记录着MongoDB数据库的不同的踪迹。


系统日志

系统日志记录着Mongodb启动和停止的操作,以及服务器在运行过程中发生的任何异常信息。

配置系统日志的方法比较简单,只需要在启动 mongod时指定一个 logpath参数即可,例如:

mongod -logpath=/data/db/logs/serverlog.log -logappend


Journal日志

Journal日志通过预写式的 redo日志为 MongoDB增加了额外的可靠性保障。开启功能时,数据的更新会先写入Journal日志,定期集中提交(目前是每100ms提交一次),然后在真实数据上执行这些变更。如果服务器安全关闭,日志会被清除。在服务器启动时,如果存在Journal日志,则会执行提交。这保证了那些已经写入Journal日志,但在服务器崩溃前还没有提交的操作能在用户连接服务器前被执行,两次提交之间的100ms时间窗口,在未来的版本中有望被缩小

启用  journal 功能非常简单,只需在 mongod后面指定 journal参数即可,例如:

mongod -journal


这样 journal信息就会放到数据库目录(默认是/data/db/)的journal 文件夹中。


oplog主从日志

MongoDB的高可用复制策略中有一种叫做 Replica Sets。Replica Sets复制过程中一个服务器充当主服务器,而一个或多个服务器充当从服务器,主服务器将更新写入一个本地的collection中,这个collection记录着发生在主服务器的更新操作,并将这些操作分发到从服务器上。

这个日志是一个Capped Collection且有大小之分,所以最好在mongod启动时配置好大小(单位:MB),例如:

mongod - oplogSize=1024


慢查询日志

慢查询日志记录了执行时间超过所设定时间阀值的操作语句,慢查询日志对于发现性能有问题的语句很有帮助,建议开启并经常分析该日志的内容

想要配置这个功能只需要在 mongod 启动时指定profile参数即可。例如,想要将超过5秒的操作都记录,可以使用如下语句:

mongod --profile=1 --slowms=5

系统运行一段时间后,可以通过查看db.system.profile这个collection来获取慢日志信息。

你可能感兴趣的:(mongodb)