通过对Nginx访问日志进行分析即可。

   

#!/bin/bashfunction define(){    ori_log_path="/var/log/nginx/abc.access.log"    tmp_log_path="/var/log/nginx/5min_abc.access.log"    date_stamp=`date -d "-5min" +%Y:%H:%M:%S`    day_stamp=`date +%d`}function gather(){    awk -F '[/ "\[]' -vnstamp="$date_stamp" -vdstamp="$day_stamp" '$7>=nstamp && $5==dstamp' ${ori_log_path} > ${tmp_log_path}    log_num=`cat ${tmp_log_path} | wc -l`    request_time=`awk '{print $(NF-1)}' ${tmp_log_path} | awk '{sum+=$1}END{print sum}'`    ave_request_time=`echo | awk "{print ${request_time}/${log_num}}" `    rm -f /var/log/nginx/5min_abc.access.log}function output(){    echo "abc aver request time is ${ave_request_time}"    echo "abc request total is ${log_num}"}function main(){    define    gather    output}main

    脚本很简单,今天需要用,就写出来记录在这里了。就是锁定最近5分钟的访问日志,通过整理其内容,获取到日志条目数和相应时间的总数,计算即可。

    我这里的日志格式,倒数第二列是相应时间。