最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
怎么通过 $request_method 变量在日志中按 GET/POST/OPTIONS 分类统计接口调用频次
时间:2026-07-04 10:07:51 编辑:袖梨 来源:一聚教程网
直接在 Nginx log_format 中引用 $request_method 并配合日志分析工具可按 HTTP 方法统计接口调用频次;需先定义含该变量的日志格式,再启用并用 awk、GoAccess、ELK 等工具进行分类、聚合或可视化分析。
直接在 Nginx 的 log_format 中引用 $request_method,再配合日志分析工具(如 awk、grep、goaccess 或 ELK),就能按 HTTP 方法分类统计接口调用频次。
配置带请求方法的日志格式
在 http 块中定义一个包含 $request_method 的日志格式:
log_format method_log '$remote_addr - $remote_user [$time_local] ' '"$request_method $request_uri $http_version" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"';
然后在 server 或 location 块中启用该格式:
access_log /var/log/nginx/api_access.log method_log;
用 awk 快速统计各方法出现次数
假设日志路径为 /var/log/nginx/api_access.log,运行以下命令可统计 GET/POST/OPTIONS 等方法的总调用次数:
awk '{print $4}' /var/log/nginx/api_access.log | sort | uniq -c | sort -nr- 若只关心前三类,加过滤:
awk '$4 ~ /^(GET|POST|OPTIONS)$/ {print $4}' ... | sort | uniq -c - 注意:$4 是上面
method_log中"$request_method所在字段(引号内第一个词),实际位置取决于你的 log_format 字段分隔方式;可用head -1 api_access.log | cut -d' ' -f4确认
按时间+方法聚合(例如每小时 POST 量)
结合 $time_local 可做更细粒度分析。例如提取「小时 + 方法」组合计数:
awk '{gsub(/[|:/," ",$3); print substr($3,1,2) " " $4}' /var/log/nginx/api_access.log | sort | uniq -c- 输出类似:
1234 08 POST,表示 8 点钟有 1234 次 POST 请求 - 想看某接口的特定方法趋势?加 URI 过滤:
awk '$7 ~ /^/api/user/ && $4 == "POST" {print substr($3,1,2)}' ...
进阶:接入实时或可视化分析
单靠文本日志适合临时排查,长期监控建议对接标准工具:
- 用 GoAccess:支持解析自定义 log_format,启动时指定
--log-format和--date-format,界面直接筛选 method 维度 - 导入 Elasticsearch:用 Logstash 或 Filebeat 采集,将
$request_method映射为 keyword 字段,Kibana 中建 Terms 聚合图表 - 简单服务端脚本:用 Python 的
collections.Counter读取日志行,按 method 分组并写入 CSV,供 Excel 或 Grafana 展示
相关文章
- 《明日方舟终末地》陈千语怎么样-陈千语值得培养吗 07-04
- 《明日方舟终末地》余烬怎样配队-余烬阵容搭配推荐 07-04
- 《明日方舟终末地》骏卫怎么样-骏卫值得培养吗 07-04
- 《明日方舟终末地》莱万汀怎样配队-莱万汀强力配队推荐 07-04
- 《明日方舟终末地》原木怎样获得-原木获得方法 07-04
- 《长生天机降世》太虚境十天智遗迹幻境通关攻略-详细打法解析 07-04