实现自动分割MongoDB日志的脚本介绍
发布时间:2023-12-19 19:59:55 所属栏目:系统 来源:DaWei
导读: 今天就跟大家聊聊有关“实现自动分割MongoDB日志的脚本怎么写”的内容,可能很多人都不太了解,为了让大家认识和更进一步的了解,小编给大家总结了以下内容,希望这篇“实现
今天就跟大家聊聊有关“实现自动分割MongoDB日志的脚本怎么写”的内容,可能很多人都不太了解,为了让大家认识和更进一步的了解,小编给大家总结了以下内容,希望这篇“实现自动分割MongoDB日志的脚本怎么写”文章能对大家有帮助。 其实所谓自动分割MongoDB日志文件,就是指Rotate MongoDB log files,即让MongoDB每天(或每个星期,可自定义控制)生成一个日志文件,而不是将MongoDB所有的运行日志都放置在一个文件中,这样每个日志文件都相对较小,定位问题也更容易。 现在以一个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 到此这篇关于“实现自动分割MongoDB日志的脚本怎么写”的文章就介绍到这了,更多相关实现自动分割MongoDB日志的脚本怎么写内容,小编将为大家输出更多高质量的实用文章! (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐