欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MongoDB运行日志实现自动分割的方法实例

程序员文章站 2022-03-22 13:38:11
前言 其实所谓自动分割mongodb日志文件,就是指rotate mongodb log files,即让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运行日志自动分割的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。