Mongodb日志定时切换
来源:互联网 发布:迈达斯桥梁软件培训班 编辑:程序博客网 时间:2024/06/18 09:04
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_DATEelse mkdir /mongodb/log/$CURRENT_MONTH/$LAST_DATE mv *.log.* /mongodb/log/$CURRENT_MONTH/$LAST_DATEfi
番外篇:
1、 在js中使用while进行循环,运行sh命令执行js文件。当kill -2时,程序没有被杀死,直接使用kill -9 ,进程进入了僵尸状态,该进程就无法再接收任何的信号。这种情况下必须 ps –ef 得到ppid然后先杀掉父进程,作为子进程将会随后死亡
2、 在mongodb查询过程中可以使用maxTimsMS来限制查询的时间,避免长时间的查询造成数据库的死亡。或者使用KillOperator来杀掉某个正在进行的操作。但是必须非常的注意,这个操作的命令必须只是客户端的,不能是系统的命令,比如shard正在迁移之类的命令。
- Mongodb日志定时切换
- mongodb 定时切割日志
- Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录
- mongoDB 日志
- MongoDB日志
- MongoDB日志
- linux定时备份mongodb
- mongoDB 定时清理历史数据
- linux定时备份mongodb
- mongodb 定时备份
- MongoDB 定时备份
- MongoDB 定时备份
- MongoDB 定时备份
- Mongodb 开启定时备份
- js: 文字定时切换
- 定时循环切换背景图片
- ViewPager定时切换
- ADSL命令定时切换
- #ASM 翻译系列第十七弹:ASM Internal ASM Disk Directory
- Lucene
- 机器学习练习(八)—— 异常检测与推荐
- 怎么在海量数据中找出重复次数最多的一个
- Git里设置大小写敏感
- Mongodb日志定时切换
- Apache Beam程序向导4
- php 乐观锁
- Android总结:内存泄露
- Android程序保活
- BZOJ 3809: Gty的二逼妹子序列 莫队套分块
- matlab 对数组随机不放回采样
- mysql的查询、子查询及连接查询
- Nagios 搭建