Mongodb日志定时切换

Mongodb日志切割

        在最初设计mongodb数据库的时候,依据客户端查询来设计集合的片键及索引,最近几天突然需要查询历史数据进行分析,我们的有些集合count达到亿条以上,每个文档几百个字段。突如其来的查询分析,数据库非常的卡,尤其这几天刚刚加入一个新的分片。前天上午来看,发现主分片竟然奔溃了,至于为什么查询量大,数据库会奔溃,需要后续进行分析。

         遇到问题第一反应是看日志文件,拿到notepad之后由于文件太大无法打开,只能采用重启,然后开始查询mongodb日志管理的文档。Mongodb官网提出可以对日志进行切换。这种切换方式为:对当前的mongod或者mongos的当前日志文件进行重命名,加入当前时间,然后打开一个新的log文件,告诉所有的log写入到新的文件中。(注意千万不要自己在没有停止mongod的时候,直接mv然后再重新生成一个新的文件)。在mongodb中切换日志文件可以采用几种方式:

1.logRotate

        默认情况下,Mongodb是开启--logRotaterename选项的,在rename的情况下,可以在log文件中添加UTC时间戳的后缀。在admin数据库中,执行命令db.runCommand({logRotate:1})告诉数据库进行日志切换。会生成:log_rout.log.2017-02-22T02-10-09 类似的日志文件。这里有8个小时的时区问题。

2.syslog

         利用syslog选项,使用系统的logrotate,这种情况下不再需要开启logpath选项,还没有进行深入的了解。

3.SIGUSR1

         在linux下,可以使用kill –SIGUSR1(pid of mongod),对mongos及mongod都适用。

         如果希望定时生成日志文件,而不是人工的每天执行命令。因为我们的当前的集群方式为:mongos+mongod(配置副本集)+mongod(分片),所以如果可以ps –aux|grep mongod可以得到数组,然后直接使用kill –SiGUSR1命令就可以了。编写完sh命令之后,无法识别-SIGUSR1。

         选择第一种方式进入mongodb中,编写js脚本,然后sh命令调用这个js命令,指定一个linux的任务。Linux的任务分为当前用户任务,系统用户。最好选择crontab –e直接进行编辑,30 10 * * * /bin/sh mongo_log_mgr.sh,制定了一个定时的10点30分钟执行的sh脚本,但是没有执行。查看任务crontab –l确认这个任务是存在的。tail -f /var/log/cron查看任务的情况:


Feb 22 09:09:12 dq36-360114a crontab[20423]: (root) REPLACE (root)
Feb 22 09:09:12 dq36-360114a crontab[20423]: (root) END EDIT (root)
Feb 22 09:10:01 dq36-360114a crond[20117]: (root) RELOAD(/var/spool/cron/root)
Feb 22 09:10:01 dq36-360114a CROND[20447]: (root) CMD (/bin/sh /root/ shell_script/mongodb/mongo_log_mgr.sh)

是的,任务是已经启动,有执行的。单独执行该shell命令,没有问题。测试一个hello.sh命令好了,是的,加上绝对路径就ok了:任务改为:

30 10 ** * /bin/sh /root/shell_script/mongodb/mongo_log_mgr.sh



在sh中,mongo中有一个选项可以直接运行js文件,sh中命令如下:

/usr/local/bin/mongo  -u XXX -p XXX--authenticationDatabase admin 172.19.185.212:27017/admin --quiet /root/ shell_script/mongodb/mongo_log.js

如果希望将日志文件分为若干个文件夹,以便于查找某一天的日志,先睡眠,因为日志的移动可能需要时间,然后根据当天的日期创建文件夹.

sleep 30m

CURRENT_MONTH=$(date +%Y-%m)
CURRENT_DAY=$(date +%d)
LAST_DATE=$(date -d last-day +%Y-%m-%d)
#如果是第一天则创建一个新的文件夹
if [ $CURRENT_DAY = 01 ] 
then
    mkdir /mongodb/log/$CURRENT_MONTH
    LAST_MONTH=$(date -d last-month +%Y-%m)
    mkdir /mongodb/log/$LAST_MONTH/$LAST_DATE
    mv *.log.* /mongodb/log/$LAST_MONTH/$LAST_DATE
else
   mkdir /mongodb/log/$CURRENT_MONTH/$LAST_DATE
   mv *.log.* /mongodb/log/$CURRENT_MONTH/$LAST_DATE
fi

 

番外篇:

1、   在js中使用while进行循环,运行sh命令执行js文件。当kill -2时,程序没有被杀死,直接使用kill -9 ,进程进入了僵尸状态,该进程就无法再接收任何的信号。这种情况下必须 ps –ef 得到ppid然后先杀掉父进程,作为子进程将会随后死亡

2、   在mongodb查询过程中可以使用maxTimsMS来限制查询的时间,避免长时间的查询造成数据库的死亡。或者使用KillOperator来杀掉某个正在进行的操作。但是必须非常的注意,这个操作的命令必须只是客户端的,不能是系统的命令,比如shard正在迁移之类的命令。


猜你喜欢

转载自blog.csdn.net/tang_jin2015/article/details/56481871