一、为什么对日志进行分割。
1.nginx日志默认情况下统统写入到一个文件中,文件会变的越来越大.
2.单个的日志文件非常不方便查看分析。
二、简析日志分割。
不论是windows还是linux,对日志的分割都是一条思路。即:
1.对现有日志文件进行重命名。
2.生成新的日志文件。
3.定制脚本,定时执行.
三、日志分割实操。
windows系统:
1.logcut.bat
#定义时间(年月日)
for /f "tokens=1 delims=/ " %%j in ("%date%") do set d1=%%j
for /f "tokens=2 delims=/ " %%j in ("%date%") do set d2=%%j
for /f "tokens=3 delims=/ " %%j in ("%date%") do set d3=%%j
#创建目录便于查看
set backupdir=C:\nginx\logs\%d1%\%d2%\%d3%
mkdir %backupdir%
#移动原有日志,相当于重命名
move F:\nginx\access.log %backupdir%
#重开日志,生成新的日志文件
F:\nginx\nginx.exe -s reopen
2.通过windows的计划任务来实现定时分割日志(本人使用的windows2012 r2)
linux系统:
1.logcut.sh
#!/bin/sh
#定义日志格式
Dateformat=`date +%Y%m%d`
#定义日志目录
Basedir="/application/nginx"
Nginxlogdir="$Basedir/logs"
#定义分割的日志
Logname="access"
#判断是否存在日志文件
[ -d $Nginxlogdir ] && cd $Nginxlogdir||exit 1
[ -f ${Logname}.log ]||exit 1
#对原有的日志文件进行修改
/bin/mv $Logname.log ${Dateformat}_$Logname.log
#重新生成nginx日志
$Basedir/sbin/nginx -s reload
2.定时任务,实现功能。
crontab -l
#logs cut
00 00 * * * sh /server/scripts/logcut.sh &>/dev/null
原文地址:http://blog.51cto.com/13043960/2105850