nginx允许针对不同的server做不同的log(有的web服务器不支持),默认有个main格式的日志,如
server {
listen ;
server_name a.com; //需更改 host
location / {
root a.com; //根目录定位
index index.html index.htm;
}
access_log logs/a.com.access.log main; //要把main格式的注释去掉
}
1.date
date #查看时间
date -s '2013-09-21 19:00:38' #修改时间
clock -w #写入cmos
date -d today +%Y%m%d #查看今天的日期并格式化
2.shell脚本
mkdir /date #创建date目录
cd /date/
vim runlog.sh
runlog.sh 内容:
#! /bin/bash
LOGPATH=/usr/local/nginx/logs/a.com.access.log #原始日志文件
BASEPATH=/date/$(date -d today +%Y%m) #新路径
mkdir -p $BASEPATH #以月为单位创建文件夹
bak=$BASEPATH/$(date -d today +%Y%m%d%H%M).a.com.access.log #新路径及文件名
mv $LOGPATH $bak #移动
touch $LOGPATH #新创建log文件
kill -USR1 `cat /usr/local/nginx/logs/nginx.pid` # 重读日志
保存退出,然后
内容
*/1 * * * * sh /date/runlog.sh
#分 时 日 月 周 我这里为了看效果,每分钟执行runlog.sh
保存退出即可:
