zoukankan      html  css  js  c++  java
  • Nginx 的 access log 如何以 json 形式记录?

    Nginx 的 access log 默认是以空格分隔的字符串形式记录的,格式如下

    log_format proxy '[$time_local] $remote_addr '
                         '$protocol $status $bytes_received $bytes_sent '
                         '$session_time "$upstream_addr" '
                         '"$upstream_bytes_sent" "$upstream_bytes_received" "$upstream_connect_time" $upstream_session_time';

    官方支持json格式

    Syntax: log_format name [escape=default|json|nonestring ...;
    Default:
    Context: stream

    Specifies the log format, for example:

    log_format proxy '$remote_addr [$time_local] '
                     '$protocol $status $bytes_sent $bytes_received '
                     '$session_time "$upstream_addr" '
                     '"$upstream_bytes_sent" "$upstream_bytes_received" "$upstream_connect_time"';
    

    The escape parameter (1.11.8) allows setting json or default characters escaping in variables, by default, default escaping is used. The none parameter (1.13.10) disables escaping.

     这里需要注意的是从 1.11.8 开始 Nginx 已经支持 json 格式,如果版本低于这个建议使用 nginx-http-json-log 扩展

    log_format json_combined escape=json '{"@timestamp":"$time_iso8601",'
                          '"@source":"$server_addr",'
                          '"@nginx_fields":{'
                          '"remote_addr":"$remote_addr",'
                          '"remote_user":"$remote_user",'
                          '"body_bytes_sent":"$body_bytes_sent",'
                          '"request_time":"$request_time",'
                          '"status":"$status",'
                          '"host":"$host",'
                          '"uri":"$uri",'
                          '"server":"$server_name",'
                          '"port":"$server_port",'
                          '"protocol":"$server_protocol",'
                          '"request_uri":"$request_uri",'
                          '"request_body":"$request_body",'
                          '"request_method":"$request_method",'
                          '"http_referrer":"$http_referer",'
                          '"body_bytes_sent":"$body_bytes_sent",'
                          '"http_x_forwarded_for":"$http_x_forwarded_for",'
                          '"http_user_agent":"$http_user_agent",'
                          '"upstream_response_time":"$upstream_response_time",'
                          '"upstream_addr":"$upstream_addr"}}';

     json格式比较直观,但数据量会变大

  • 相关阅读:
    如何在IIS7/7.5上配置IISADMPWD
    运用DebugDiag诊断ASP.Net异常
    vuecli3修改项目启动端口
    彻底删除vscode及安装的插件和个人配置信息
    angular中的 input select 值绑定无效,以及多出一个空白选项问题
    简述MVC模式
    vuecli3 运行报错
    前端开发规范
    nodejs 下载最新版本
    小程序 自定义弹窗出现后存在滚动穿透问题
  • 原文地址:https://www.cnblogs.com/felixzh/p/8710399.html
Copyright © 2011-2022 走看看