在Debian系统中,MongoDB的日志轮转可以通过配置logrotate工具来实现。以下是设置MongoDB日志轮转的步骤:
logrotate已安装:sudo apt-get update
sudo apt-get install logrotate
logrotate配置文件,专门用于MongoDB:sudo nano /etc/logrotate.d/mongodb
/path/to/mongodb.log {
size 500M
rotate 5
compress
missingok
notifempty
create 640 mongodb mongodb
postrotate
if [ -f /var/run/mongodb.pid ]; then
kill -SIGUSR1 `cat /var/run/mongodb.pid`
fi
endscript
}
请注意,您需要将/path/to/mongodb.log替换为实际的MongoDB日志文件路径。
这个配置文件的含义如下:
size 500M:当日志文件达到500MB时,将触发日志轮转。rotate 5:保留5个轮转后的日志文件。compress:压缩轮转后的日志文件。missingok:如果日志文件不存在,不会产生错误。notifempty:如果日志文件为空,则不进行轮转。create 640 mongodb mongodb:创建新的日志文件,权限为640,属主为mongodb用户,属组为mongodb组。postrotate和endscript之间的脚本会在日志轮转后执行。这里我们发送一个SIGUSR1信号给MongoDB进程,通知它重新打开日志文件。保存并关闭配置文件。
测试logrotate配置是否正确:
sudo logrotate -f /etc/logrotate.d/mongodb
如果没有错误信息,说明配置正确。
现在,MongoDB的日志轮转已经设置好了。logrotate会自动按照配置的时间间隔(默认每天)检查日志文件,并根据需要进行轮转。