nginx訪問日誌配置+日誌切割+不記錄靜態文件日誌+設置靜態文件過期時間
阿新 • • 發佈:2018-03-15
nginx日誌 nginx日誌切割 nginx設置靜態文件過期時間與不記錄 nginx設置日誌格式 nginx訪問日誌
查看nginx.conf文件
vim /usr/local/nginx/conf/nginx.conf
中間有一行是定義log的格式
log_format combined_realip ‘$remote_addr $http_x_forwarded_for [$time_local]‘
‘ $host "$request_uri" $status‘
‘ "$http_referer" "$http_user_agent"‘;
其中‘‘包圍起來的不算一行,只是為了美觀才分行顯示,分行顯示就必須加上‘‘號;
含義:
combined_realip:定義日誌格式別名,默認為combined_realip,這裏我會改為test001;
$remote_addr:客戶端ip也就是出口公網ip;
$http_x_forwarded_for:代理服務器ip;
$time_local:服務器本地時間;
$host:訪問主機名(域名);
$request_uri:訪問的url地址;
$status:狀態碼,比如404;
$http_referer:referer;
$http_user_agent:也就是訪問的瀏覽器類型,比如傲遊7;
編輯虛擬web配置
vim /usr/local/nginx/conf/vhost/test.com.conf
增加access_log /tmp/test.com.log combined_realip;
其中combined_realip是定義名稱,記得與nginx.conf匹配;
檢錯與重新加載
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload
訪問與測試
curl -x127.0.0.1:80 test.com/1.html -I
訪問成功200
查看日誌
cat /tmp/test.com.log
127.0.0.1 - [15/Mar/2018:03:13:28 +0800] test.com "/1.html" 200 "-" "curl/7.29.0"
日誌切割
創建shell腳本
vim /usr/local/sbin/nginx_log_rotate.sh
代碼
#! /bin/bash ## 假設nginx的日誌存放路徑為/tmp/ d=`date -d "-1 day" +%Y%m%d` logdir="/tmp/" nginx_pid="/usr/local/nginx/logs/nginx.pid" cd $logdir for log in `ls *.log` do mv $log $log-$d done /bin/kill -HUP `cat $nginx_pid`
執行腳本(可不執行)
sh -x /usr/local/sbin/nginx_log_rotate.sh
[root@shu-test ~]# sh -x /usr/local/sbin/nginx_log_rotate.sh
++ date -d ‘-1 day‘ +%Y%m%d
+ d=20180314
+ logdir=/tmp/
+ nginx_pid=/usr/local/nginx/logs/nginx.pid
+ cd /tmp/
++ ls php_errors.log test.com.log
+ for log in ‘`ls *.log`‘
+ mv php_errors.log php_errors.log-20180314
+ for log in ‘`ls *.log`‘
+ mv test.com.log test.com.log-20180314
++ cat /usr/local/nginx/logs/nginx.pid
+ /bin/kill -HUP 1574
[root@shu-test ~]#
任務計劃執行腳本
crontab -e
寫入腳本
0 0 * * * /bin/bash /usr/local/sbin/nginx_log_rotate.sh
意思:每天淩晨0點執行腳本/usr/local/sbin/nginx_log_rotate.sh
如何腳本刪除log
find /tmp/ -name *.log-* -type f -mtime +30 |xargs rm
靜態文件不記錄日誌和過期時間
編輯web虛擬文件
vim /usr/local/nginx/conf/vhost/test.com.conf
增加代碼
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 7d;
access_log off;
}
location ~ .*\.(js|css)$
{
expires 12h;
access_log off;
}
所有代碼預覽
server
{
listen 80;
server_name test.comtest1.comtest2.com;
index index.html index.htm index.php;
root /data/wwwroot/test.com;
if ($host != ‘test.com‘ ) {
rewrite ^/(.*)$ http://test.com/$1 permanent;
}
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 7d;
access_log off;
}
location ~ .*\.(js|css)$
{
expires 12h;
access_log off;
}
access_log /tmp/test.com.log test;
}
檢錯與重新加載
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload
nginx訪問日誌配置+日誌切割+不記錄靜態文件日誌+設置靜態文件過期時間