nginx access_log日誌pv uv統計並通過接口發佈

首先指定nginx的access_log記錄的格式:

log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

編寫腳本:
#cat nginx_access_logs_count.sh

PROJECT=fjl_cms
ADD_TIME=$(date -d "today" +"%F")
PV=$(awk '{print $7}' /home/wwwlog/www. xxx-cms.cn/access.log | wc -l)
UV=$(awk '{print $1}' /home/wwwlog/www.xxx-cms.cn/access.log | sort | uniq -c |wc -l)
IP=$(cat /home/wwwlog/www.xxx-cms.cn/access.log | awk '{print $1}' | sort -k1 -r | uniq | wc -l)

curl -v http://vip.xxx.com/api/pvlog?name="$PROJECT"\&add_time="$ADD_TIME"\&pv="$PV"\&uv="$UV"\&ip="$IP"

說明:
1、將命令執行的結果賦值給變量:
變量名=$(命令)
2、調用api接口並傳遞參數:
使用curl命令調用接口
將之前定義的變量放到參數裏$變量名,並用雙引號" "轉爲字符串,\轉義&符號

在計劃任務中執行:
crontab -e

#每天23點59執行pv、uv統計腳本
59 23 * /usr/bin/sh /root/nginx_access_logs_count.sh

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章