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

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值