好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

前言

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

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

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

1、配置MongoDB实例启动参数

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

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日志脚本

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

#!/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定时任务

?

1

vi /etc/crontab

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

?

1

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

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

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

如下所示:

?

1

2

3

4

5

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运行日志自动分割的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

原文链接:http://blog.csdn.net/wangkai_123456/article/details/53705592

查看更多关于MongoDB运行日志实现自动分割的方法实例的详细内容...

  阅读:36次