发布于 2017-03-11 03:14:41 | 230 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的MongoDB手册,程序狗速度看过来!

MongoDB 分布式文件存储的数据库

MongoDB 是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。


这篇文章主要给大家介绍了关于MongoDB运行日志实现自动分割的方法,文中以一个MongoDB实例为例,写了一个脚本来实现自动分割MongoDB日志,有需要的朋友可以参考借鉴,下面来一起看看吧。

前言

其实所谓自动分割MongoDB日志文件,就是指Rotate MongoDB log files,即让MongoDB每天(或每个星期,可自定义控制)生成一个日志文件,而不是将MongoDB所有的运行日志都放置在一个文件中,这样每个日志文件都相对较小,定位问题也更容易。

实现自动分割MongoDB日志的方法可以参考:https://docs.mongodb.com/manual/tutorial/rotate-log-files/

现在以一个MongoDB实例为例,可以写一个脚本来实现自动分割MongoDB日志

1、配置MongoDB实例启动参数


security: 
 keyFile: /usr/local/mongodb/authentication/keyFile 
sharding: 
 clusterRole: shardsvr 
replication: 
 replSetName: rs3 
net: 
 port: 27023 
storage: 
 dbPath: /data/db_delay_rs3 
systemLog: 
 path: /data/log_delay_rs3/mongodb.log 
 destination: file 
 logAppend: true 
 logRotate: rename 
processManagement: 
 fork: true 

配置MongoDB系统日志保存路径,并配置logRotate参数为rename

2、编写自动分割MongoDB日志脚本


#!/bin/bash 
#Rotate the MongoDB logs to prevent a single logfile from consuming too much disk space. 
 
app=mongod 
 
mongodPath=/usr/local/mongodb/bin/ 
 
pidArray=$(pidof $mongodPath/$app) 
 
for pid in $pidArray;do 
if [ $pid ] 
then 
 kill -SIGUSR1 $pid 
fi 
done 
 
exit 

:wq保存,并命名为logRotate.sh,保存到目录/data/logRotate/

3、设置Linux定时任务


vi /etc/crontab

在打开的文件底部添加如下内容


59 23 * * * root /data/logRotate/logRotate.sh 

:wq保存,表示配置一个定时任务,定时每天23:59以root身份执行脚本/data/logRotate/logRotate.sh,实现定时自动分割MongoDB日志

至此,就实现了自动分割MongoDB日志,MongoDB每天都会生成一个新的日志文件,日志文件的命名带有标识文件日期的时间戳。

如下所示:


mongodb.log  mongodb.log.2016-12-08T15-59-01 mongodb.log.2016-12-13T15-59-01
mongodb.log.2016-12-06T07-14-10 mongodb.log.2016-12-09T15-59-01 mongodb.log.2016-12-14T15-59-01
mongodb.log.2016-12-06T15-59-01 mongodb.log.2016-12-10T15-59-01 mongodb.log.2016-12-15T15-59-01
mongodb.log.2016-12-07T01-54-05 mongodb.log.2016-12-11T15-59-01 mongodb.log.2016-12-16T15-59-01
mongodb.log.2016-12-07T15-59-01 mongodb.log.2016-12-12T15-59-01

总结

以上就是关于MongoDB运行日志自动分割的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务