MongoDB运行日志自动分割

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

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

1、配置MongoDB实例启动参数

security:   
keyFile: /usr/local/mongodb/authentication/keyFilesharding:   
clusterRole: 
shardsvrreplication:   
replSetName: rs3net:   
port: 27023storage:   
dbPath: /data/db_delay_rs3systemLog:   
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运行日志自动分割)