mongo日志旋转在windows上不起作用



运行时

db.runCommand('logRotate'(

响应

{
"message" : "n/a",
"ok" : 0,
"$clusterTime" : {
"clusterTime" : "Timestamp(1618333251, 1)",
"signature" : {
"hash" : "AAAAAAAAAAAAAAAAAAAAAAAAAAA=",
"keyId" : 0
}
},
"operationTime" : "Timestamp(1618333251, 1)",
"name" : "MongoError"

}

甚至尝试了这张票中建议的方法https://jira.mongodb.org/browse/SERVER-7312当运行logrotate时,它会创建一个名为mongod.log.1的日志文件,并被mongod进程锁定。mongod.log.1只有在mongod停止/重新启动时才会被删除。

mongod.cfg中的系统日志

# where to write logging data.
systemLog:
destination: file
logAppend: true
logRotate: reopen
# configure this path appropirately and make sure the directory exists
path:  C:Program FilesMongoDBServer4.4logmongod.log

不知道如何在windows上正确旋转mongo日志?

使用mongo版本4.4.0

在Wernfried Domscheit的帮助下,经过大量的研究、数周的反复试验和挫折,我找到了一个可行的windows解决方案。


先决条件
  • 您有一个使用配置文件mongod.cfg运行的MongoDB服务
  • LogRotateWin已安装。这是一个基于unix实现的用于旋转日志文件的第三方包。它提供了许多可自定义的功能,如压缩、应用旋转、旧文件删除等。您可以在此处找到完整的选项列表LogRotateWin配置
  • Windows任务调度程序的基本知识
  • 非常基本的蝙蝠档案知识
1.调整MongoDB服务的配置文件
  1. 停止服务
  2. 打开mongod.cfg,找到配置systemLog的代码行:
# where to write logging data. 
systemLog:
destination: file
logAppend: true
path:  E:MongoDBServer4.4logmongod.log
logRotate: reopen

请确保覆盖mongod.log的路径。还要确保已设置logAppend: truelogRotate: reopen

  1. 删除当前mongod.log文件
  2. 重新启动服务
2.配置logrotate配置

这是我的配置。您可以根据自己的需要进行自定义。但是不要使用copycopytruncatecreate,并且不要删除postrotate命令!(在SourceForge的讨论线程中,我看到notifempty不工作,rotate 10导致权限错误,请参阅我在这篇文章下面的编辑(

E:MongoDBServer4.4logmongod.log {
nocompress
daily
size 100m
missingok
rotate 50
postrotate
E:logrotatenotify_mongodb_service.bat
endscript
}

此配置每天旋转未压缩的日志,或者如果大小超过100兆字节。最多存储50个日志,较旧的文件将被删除。旋转成功后将执行旋转后脚本。

3.创建notify_mongodb_service.bat文件

该文件向MongoDB服务发送一个命令,即将使用一个新文件。如果您启用了授权,您也可以添加-u username -p password

E:MongoDBServer4.4binmongo.exe --eval "db.adminCommand({ logRotate: 1 })"
  • mongo.exe的路径更改为系统上的位置
  • 保存文件并确保logrotate配置中的路径相同!(postrotateendscript之间的线路

该命令存储在一个额外的文件中,因为LogRotateWin解释mongo命令的Brackets({}(并抛出异常

4.检查是否一切正常
  1. 打开日志文件夹。您应该看到一个单独的文件mongod.log

  2. 打开一个终端,检查logrotation是否工作(即使没有触发,-f也会强制执行logrotation(:

logrotate logrotate.conf -f

应该出现一个新的日志文件。(对我来说是mongod.log.1(mongod.log应为空。

  1. 触发将被记录的内容。例如,使用monogbCompass连接到您的MongoDB。

  2. 检查mongod.log。连接应该记录在那里。

5.创建任务调度程序作业以定期运行日志轮换

我不会谈论任务调度程序的创建,但这里是我的配置示例。您可以导入该文件并根据需要对其进行修改。

还要将logrotate.exe的路径更改为系统所在的位置。

此作业每小时运行一次,以检查是否触发了logrotate的一个或多个触发器:

<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.4" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
<RegistrationInfo>
<Date>2021-12-02T17:57:55.9541897</Date>
<Author>Grayknife</Author>
<Description>Execute Logrotate Hourly</Description>
<URI>dockerLogRotate</URI>
</RegistrationInfo>
<Triggers>
<CalendarTrigger>
<Repetition>
<Interval>PT1H</Interval>
<StopAtDurationEnd>false</StopAtDurationEnd>
</Repetition>
<StartBoundary>2021-12-02T18:00:00</StartBoundary>
<ExecutionTimeLimit>PT30M</ExecutionTimeLimit>
<Enabled>true</Enabled>
<ScheduleByDay>
<DaysInterval>1</DaysInterval>
</ScheduleByDay>
</CalendarTrigger>
</Triggers>
<Principals>
<Principal id="Author">
<UserId>1234</UserId>
<LogonType>Password</LogonType>
<RunLevel>LeastPrivilege</RunLevel>
</Principal>
</Principals>
<Settings>
<MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
<DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
<StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
<AllowHardTerminate>true</AllowHardTerminate>
<StartWhenAvailable>false</StartWhenAvailable>
<RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
<IdleSettings>
<StopOnIdleEnd>true</StopOnIdleEnd>
<RestartOnIdle>false</RestartOnIdle>
</IdleSettings>
<AllowStartOnDemand>true</AllowStartOnDemand>
<Enabled>true</Enabled>
<Hidden>false</Hidden>
<RunOnlyIfIdle>false</RunOnlyIfIdle>
<DisallowStartOnRemoteAppSession>false</DisallowStartOnRemoteAppSession>
<UseUnifiedSchedulingEngine>true</UseUnifiedSchedulingEngine>
<WakeToRun>false</WakeToRun>
<ExecutionTimeLimit>PT0S</ExecutionTimeLimit>
<Priority>7</Priority>
</Settings>
<Actions Context="Author">
<Exec>
<Command>E:logrotatelogrotate.exe</Command>
<Arguments>logrotate.conf</Arguments>
<WorkingDirectory>E:logrotate</WorkingDirectory>
</Exec>
</Actions>
</Task>

我希望我能帮助别人做那本指南。


编辑2022-05-01

我遇到了logrotate在超过9个文件时抛出异常的问题:

E:logrotate>E:logrotatelogrotate.exe logrotate.conf -f
logrotate: Force option set to true
logrotate: Exception: Cannot create a file when that file already exists.
logrotate: StackTrace:    at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.__Error.WinIOError()
at System.IO.File.InternalMove(String sourceFileName, String destFileName, Boolean checkHost)
at logrotate.Program.AgeOutRotatedFiles(logrotateconf lrc, FileInfo fi, String rotate_path)
at logrotate.Program.RotateFile(logrotateconf lrc, FileInfo fi)
at logrotate.Program.Main(String[] args)
E:logrotate>E:logrotatelogrotate.exe logrotate.conf -f
logrotate: Force option set to true
logrotate: Exception: Access to the path 'E:MongoDBServer4.4logmongod.log.10' is denied.
logrotate: StackTrace:    at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.File.InternalDelete(String path, Boolean checkHost)
at System.IO.File.Delete(String path)
at logrotate.Program.DeleteRotateFile(String m_filepath, logrotateconf lrc)
at logrotate.Program.AgeOutRotatedFiles(logrotateconf lrc, FileInfo fi, String rotate_path)
at logrotate.Program.RotateFile(logrotateconf lrc, FileInfo fi)
at logrotate.Program.Main(String[] args)
E:logrotate>

目前的快速修复是设置最多9个文件。

最新更新