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

   

#!/bin/bash

function 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分钟的访问日志,通过整理其内容,获取到日志条目数和相应时间的总数,计算即可。

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