根据nginx的access_log查看接口请求时间

首先修改修改生成日志的格式,在nginx配置文件的http里添加如下内容:

log_format  '$remote_addr - $remote_user [$time_local] "$request" '
                    '$status $body_bytes_sent $request_body "$http_referer" '
                    '"$http_user_agent" "$http_x_forwarded_for"'
                     '$upstream_addr $upstream_response_time $request_time ';

然后修改nginx配置文件相应server配置

access_log  /data/wwwlogs/access_api.log   ;

标红的部分一定要相同。

分析nginx日志,例如查找响应时间大于0.02秒的请求:

cat access_api.log | awk '($NF>0.02){print $6 " " $7 " " $8 " " $11 " " $NF}' > c.txt

awk有内置的变量。对于每一个记录,即行,分隔空白字符分隔记录默认情况下,它存储在$ n个变量。如果该行有4个词,它会被存储在$1,$2,$3和 $4。$0表示整行。 NF是一个内置变量,它代表这一行有多少个被分隔的域。