NGINX日志和网页配置)
nginx日志切割
因为nginx的access.log日志会保存所有客户端连接信息,普通网站每天请求量很大,所以要每天切割(可以用nginx自带的reopen)
首先保存之前的日志
mv access.log `date +%F -d -1day`_access.log ##因为第二天肯定是备份前一天的日志
/usr/local/nginx/sbin/nginx -s reopen
发现重新生成了一个access.log,新的请求信息会到新日志里
编写自动切割日志的脚本
vim /usr/local/nginx/logs/backup.sh
#!/bin/bash
LOG_PATH=/usr/local/nginx/logs/oldlogs
#重命名日志文件,mv 会删除原文件,导致日志丢失,因为Nginx不会自己去再创建一个日志文件
CUR_LOG_PATH=/usr/local/nginx/logs
YESTERDAY=$(date +%F -d -1day)
mv ${
CUR_LOG_PATH}/access.log ${
LOG_PATH}/${
YESTERDAY}_access.log
mv ${
CUR_LOG_PATH}/error.log ${
LOG_HOME}/${
YESTERDAY}_error.log
#向 Nginx 主进程发送 USR1 信号。Nginx 里 USR1 信号是重新打开日志文件
kill -USR1 $(cat /usr/local/nginx/logs/hginx.pid)
chmod +x /usr/local/nginx/logs/backup.sh
sh /usr/local/nginx/logs/backup.sh
把命令写在crontab里,每天执行一次
crontab -e
0 0 * * * /bin/bash /usr/local/nginx/logs/backup.sh
crontab -l 查看任务
设置 access.log
在 nginx.conf 文件里配置:
access_log path [format [buffer=size] [gzip[=level]] [flush=time] [if=condition]];
path | 指定日志的存放位置。 |
format | 指定日志的格式。默认使用预定义的combined。 |
buffer | 用来指定日志写入时的缓存大小。默认是64k。 |
gzip | 日志写入前先进行压缩。压缩率可以指定,从1到9数值越大压缩比越高,同时压缩的速度也越慢。默认是1。 |
flush | 设置缓存的有效时间。如果超过flush指定的时间,缓存中的内容将被清空。 |
if | 条件判断。如果指定的条件计算为0或空字符串,那么该请求不会写入日志。 |
特殊的值off | 如果指定了该值,当前作用域下的所有的请求日志都被关闭。 |
示例
http {
...
##日志格式使用默认的combined;指定日志的缓存大小为32k;日志写入前启用gzip进行压缩,压缩比使用默认值1;缓存数据有效时间为1分钟。
access_log /var/logs/nginx-access.log buffer=32k gzip flush=1m;
...
}
access_log指令的作用域分别有http,server,location。 更里面的设置,会覆盖外面的设置。
自定义日志格式
编辑配置文件
取消日志格式的注释
vim /usr/local/nginx/conf/nginx.conf
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
在server下添加
access_log logs/westos/access.log main;
日志格式的参数
重置nginx
cd /usr/local/nginx
./sbin/ngin