一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

怎么通过 $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"';

然后在 serverlocation 块中启用该格式:

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 展示

热门栏目