nginx訪問日志并刪除指定天數(shù)前的日志記錄配置方法
說明:
操作系統(tǒng):CentOS
站點(diǎn)1:bbs.jb51.net
站點(diǎn)2:sns.jb51.net
Nginx安裝路徑:/usr/local/nginx
Nginx配置文件路徑:/usr/local/nginx/conf/nginx.conf
站點(diǎn)1配置文件路徑:/usr/local/nginx/conf/vhost/bbs.jb51.net.conf
站點(diǎn)2配置文件路徑:/usr/local/nginx/conf/vhost/sns.jb51.net.conf
目的:
1、對站點(diǎn)1和站點(diǎn)2的nginx訪問日志按天保存,日志路徑為:
站點(diǎn)1:/usr/local/nginx/logs/nginx_logs/bbs_logs
站點(diǎn)2:/usr/local/nginx/logs/nginx_logs/sns_logs
2、只保留30天以內(nèi)的日志記錄
具體操作:
1、創(chuàng)建日志存放路徑
mkdir -p /usr/local/nginx/logs/nginx_logs/bbs_logs
mkdir -p /usr/local/nginx/logs/nginx_logs/sns_logs
2、設(shè)置Nginx日志記錄格式
編輯vi /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"';
取消日志記錄格式前面的注釋,在最后添加一行,如下所示:
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'
'$http_host $upstream_status $upstream_addr $request_time $upstream_response_time'; #新添加的一行
:wq! #保存退出
3、設(shè)置虛擬主機(jī)配置文件
編輯vi /usr/local/nginx/conf/vhost/bbs.jb51.net.conf #,在bbs.jb51.net;這一行下面添加
access_log logs/bbs_access.log main; #注意這里的main要和上一步中的main一致
:wq! #保存退出
編輯vi /usr/local/nginx/conf/vhost/sns.jb51.net.conf ,在sns.jb51.net;這一行下面添加
access_log logs/sns_access.log main; #注意這里的main要和上一步中的main一致
:wq! #保存退出
service nginx reload #重新加載nginx配置文件
4、創(chuàng)建Nginx日志切割腳本
編輯vi /home/crontab/cut_nginx_log.sh
#!/bin/sh
logs_path="/usr/local/nginx/logs/"
DAYS=30
mv ${logs_path}bbs_access.log ${logs_path}nginx_logs/bbs_logs/bbs_access_$(date -d "yesterday" +"%Y%m%d").log
mv ${logs_path}sns_access.log ${logs_path}nginx_logs/sns_logs/sns_access_$(date -d "yesterday" +"%Y%m%d").log
kill -USR1 `cat /usr/local/nginx/logs/nginx.pid`
find ${logs_path}nginx_logs/bbs_logs/ -name "bbs_access_*" -type f -mtime +$DAYS -exec rm {} \;
find ${logs_path}nginx_logs/sns_logs/ -name "sns_access_*" -type f -mtime +$DAYS -exec rm {} \;
:wq! #保存退出
chmod +x /home/crontab/cut_nginx_log.sh #添加腳本執(zhí)行權(quán)限
5、添加任務(wù)計(jì)劃,修改/etc/crontab
vi /etc/crontab在最后一行添加
0 0 * * * root /home/crontab/cut_nginx_log.sh #表示每天凌晨執(zhí)行
:wq! #保存退出
6、重新啟動(dòng)crond使設(shè)置生效
/etc/rc.d/init.d/crond restart #yum install -y vixie-cron安裝計(jì)劃任務(wù),某些系統(tǒng)上可能沒有預(yù)裝
chkconfig crond on #設(shè)為開機(jī)啟動(dòng)
service crond start #啟動(dòng)
每天會在/usr/local/nginx/logs/nginx_logs/bbs_logs和/usr/local/nginx/logs/nginx_logs/sns_logs
目錄下生成類似bbs_access_20140126.log和bbs_access_20140126.log的日志文件
并且只保留最近30天的日志記錄
至此,Linux下定時(shí)切割Nginx訪問日志并刪除指定天數(shù)前的日志記錄完成。
備注:如果腳本在執(zhí)行過程中出現(xiàn)下面錯(cuò)誤
nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed
解決辦法:
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
#使用nginx -c的參數(shù)指定nginx.conf文件的位置
擴(kuò)展閱讀:Nginx訪問日志參數(shù)說明
192.168.21.1 - - [27/Jan/2014:11:28:53 +0800] "GET /2.php HTTP/1.1" 200 133 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1707.0 Safari/537.36" "-"192.168.21.128 200 127.0.0.1:9000 0.119 0.119
$remote_addr:客戶端地址 192.168.21.1
$remote_user:客戶端用戶 -
$time_local:時(shí)間和時(shí)區(qū) 27/Jan/2014:11:28:53 +0800
$request:請求的URL路徑和HTTP協(xié)議 GET /2.php HTTP/1.1
$status: HTTP狀態(tài) 200
$body_bytes_sent:發(fā)送給客戶端頁面大小 133
$http_referer:頁面跳轉(zhuǎn)來源 -
$http_user_agent:用戶訪問終端 Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1707.0 Safari/537.36
$http_x_forwarded_for:HTTP 代理中,請求端真實(shí)IP -
$http_host:用戶在瀏覽器中輸入的URL(IP或著域名)地址 192.168.21.128
$upstream_status: upstream狀態(tài) 200
$upstream_addr: 后端upstream地址及端口 127.0.0.1:9000
$request_time: 頁面訪問總時(shí)間 0.119
$upstream_response_time:頁面訪問中upstream響應(yīng)時(shí)間 0.119
相關(guān)文章
Nginx+Tomcat搭建高性能負(fù)載均衡集群的實(shí)現(xiàn)方法
這篇文章主要介紹了Nginx+Tomcat搭建高性能負(fù)載均衡集群的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03nginx 關(guān)閉默認(rèn)站點(diǎn)的方法
國內(nèi)機(jī)房一般都要求網(wǎng)站主關(guān)閉空主機(jī)頭,防止未備案的域名指向過來造成麻煩2012-09-09Nginx實(shí)現(xiàn)負(fù)載均衡和反向代理的方法
Nginx是由俄羅斯人研發(fā)的,應(yīng)對Rambler的網(wǎng)站,并且2004年發(fā)布的第一個(gè)版本,Nginx功能豐富,可作為HTTP服務(wù)器,也可作為反向代理服務(wù)器,郵件服務(wù)器,本文給大家介紹了Nginx實(shí)現(xiàn)負(fù)載均衡和反向代理的方法,需要的朋友可以參考下2024-02-02Nginx配置SSL證書部署HTTPS網(wǎng)站的方法(頒發(fā)證書)
這篇文章主要介紹了Nginx配置SSL證書部署HTTPS網(wǎng)站的方法(頒發(fā)證書),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06分析nginx日志并屏蔽采集者ip(nginx屏蔽ip配置實(shí)例)
這篇文章主要介紹了分析nginx日志并屏蔽采集者ip(nginx屏蔽ip配置實(shí)例),本文先是講解了分析需要屏蔽日志的方法,然后講解了Nginx中屏蔽IP的配置方法,需要的朋友可以參考下2015-02-02在Ubuntu系統(tǒng)上安裝Nginx服務(wù)器的簡單方法
這篇文章主要介紹了在Ubuntu系統(tǒng)上安裝Nginx服務(wù)器的簡單方法,包括打開和關(guān)閉Nginx的指令,需要的朋友可以參考下2015-08-08Nginx編譯參數(shù)大全 configure參數(shù)中文詳解
這篇文章主要介紹了Nginx編譯參數(shù)大全,Nginx configure參數(shù)中文詳解,需要的朋友可以參考下2014-04-04