大数据技术之MongoDB日志切换(Rotate Log Files)指南
沉沙 2019-04-09 来源 : 阅读 345 评论 0

摘要:本篇文章探讨了大数据技术之MongoDB日志切换(Rotate Log Files)指南,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

本篇文章探讨了大数据技术之MongoDB日志切换(Rotate Log Files)指南,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

大数据技术之MongoDB日志切换(Rotate Log Files)指南

MongoDB默认情况下不会自动的切换轮转日志的,这将会导致日志日渐增大,在繁忙的业务下,日志增长量非常大的。如此之大的日志文件,查看某天的日志也不太方便。因此,需要对mongodb 日志文件进行切换。

日志切换行为

--logRotate <string>

默认值:rename

3.0.0版本新特性:指定logRotate行为。

指定为rename或者reopen。

rename 重命名日志文件。

reopen 关闭并重新打开日志文件遵循典型的Linux/Unix日志切换行为。当使用Linux/Unix logrotate工具时,使用reopen避免日志丢失。

如果指定reopen时,也必须同时使用—logappend

默认日志切换行为

默认情况下,MongoDB使用--logRotate rename行为。使用rename,mongod或mongos通过在文件名称末尾添加UTC(GMT)时间戳的方式重命名当前的日志文件,然后打开新的日志文件,关闭之前旧的日志文件,并发送所有新的日志信息到新的日志文件中。

1. 启动mongod实例。  

mongod –v –logpath /var/log/mongodb/server1.log


你也可以显式指定--logRotate rename

2. 列出日志文件。  
在另一个终端中,列出匹配文件:    

ls /var/log/mongodb/server1.log*


结果将包含一个日志文件,server1.log。

3. 切换日志文件。  
在mongo shell下,从admin数据库运行logRotate命令切换日志文件:    

use admin    
db.runCommand({logRotate:1})

4. 查看新的日志文件。  
列出新的日志文件,来查看新创建的日志:    

ls /var/log/mongodb/server1.log*


应该列出两个日志文件:server1.log,它是当日志文件重新打开时mongod或mongos创建的;server1.log.<timestamp>,重命名的原始日志文件。    
切换日志文件不会修改旧的切换日志文件。当你切换日志时,你将通过附加时间戳来重命名server1.log文件,并且一个新的空server1.log文件将会收到所有新的日志输入。

使用--logRotate reopen切换日志

3.0.0版本的新特性。

使用--logRotate reopen切换日志,关闭并打开日志文件遵循典型的Linux/Unix日志切换行为。

1. 启动mongod实例,指定--logRotate参数值为reopen。  

mongod –v –logpath /var/log/mongodb/server1.log –logRotate reopen –logappend


你必须使用带有--logRoate reopen参数的--logappend选项。

2. 列出日志文件。  
在另一个终端,列出匹配的文件:    

ls /var/log/mongodb/server1.log*


结果包含一个日志文件,server1.log。

3. 切换日志文件。  
在mongo shell中,从admin数据库执行logRotate命令执行日志文件切换:    

use admin    
db.runCommand({logRotate:1})

 
你应该使用一个外部进程重命名日志文件,遵循典型的Linux/Unix日志切换行为。

通过syslog切换日志

2.2版本的新特性。

通过syslog切换日志,mongod发送日志数据到syslog而不是写入到文件。

1. 启动mongod实例使用--syslog选项  

mongod –syslog


不要包含--logpath。因为--syslog告诉mongod发送日志数据到syslog,所以指定--logpath将导致错误。    
为了指定用于记录信息到syslog的设备级别,使用--syslogFacility选项或者systemLog.syslogFacility配置设置。

2. 使用系统默认的日志切换机制存储并切换日志输出。

使用SIGUSR1强制日志切换

对于Linux/Unix系统,你可以对于一个单一进程使用SIGUSR1信号来切换日志,如下:

Kill –SIGUSR1 <mongod process id>

      本文由职坐标整理发布,学习更多的相关知识,请关注职坐标IT知识库!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程