nginx自定义日志格式、nginx日志格式

本文详细解读Nginx配置文件的关键参数,教你如何设置日志格式,以及如何根据实际需求进行负载均衡配置。从基础概念到实战应用,适合初学者和进阶者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

保姆级别的来了。
首先整明白nginx配置文件的里面的参数的意思。废话不多说直接上解释

$arg_PARAMETER  HTTP 请求中某个参数的值,
Eg:/index.php?site=www.ttlsa.com,可以用$arg_site取得www.ttlsa.com这个值.
 
$args HTTP 请求中的完整参数。
Eg:例如,在请求/index.php?width=400&height=200 中,$args表示字符串width=400&height=200.
 
$binary_remote_addr 二进制格式的客户端地址。例如:\x0A\xE0B\x0E
 
$body_bytes_sent 表示在向客户端发送的http响应中,包体部分的字节数
 
$content_length 表示客户端请求头部中的Content-Length 字段
 
$content_type 表示客户端请求头部中的Content-Type 字段
 
$cookie_COOKIE 表示在客户端请求头部中的cookie 字段
 
$document_root 表示当前请求所使用的root 配置项的值
 
$uri 表示当前请求的URI,不带任何参数
 
$document_uri 与$uri 含义相同
$request_uri 表示客户端发来的原始请求URI,带完整的参数。$uri和$document_uri未必是用户的原始请求,在内部重定向后可能是重定向后的URI,而$request_uri 永远不会改变,始终是客户端的原始URI.
 
$host 表示客户端请求头部中的Host字段。如果Host字段不存在,则以实际处理的server(虚拟主机)名称代替。如果Host字段中带有端口,如IP:PORT,那么$host是去掉端口的,它的值为IP。$host 是全小写的。这些特性与http_HEADER中的http_host不同,http_host只取出Host头部对应的值。 
 
$hostname 表示 Nginx所在机器的名称,与 gethostbyname调用返回的值相同 
 
$http_HEADER 表示当前 HTTP请求中相应头部的值。HEADER名称全小写。例如,示请求中 Host头部对应的值 用 $http_host表 
 
$sent_http_HEADER 表示返回客户端的 HTTP响应中相应头部的值。HEADER名称全小写。例如,用 $sent_ http_content_type表示响应中 Content-Type头部对应的值 
 
$is_args 表示请求中的 URI是否带参数,如果带参数,$is_args值为 ?,如果不带参数,则是空字符串 
 
$limit_rate 表示当前连接的限速是多少,0表示无限速 
 
$nginx_version 表示当前 Nginx的版本号 
 
$query_string 请求 URI中的参数,与 $args相同,然而 $query_string是只读的不会改变 
 
$remote_addr 表示客户端的地址 
 
$remote_port 表示客户端连接使用的端口 
 
$remote_user 表示使用 Auth Basic Module时定义的用户名 
 
$request_filename 表示用户请求中的 URI经过 root或 alias转换后的文件路径 
 
$request_body 表示 HTTP请求中的包体,该参数只在 proxy_pass或 fastcgi_pass中有意义 
 
$request_body_file 表示 HTTP请求中的包体存储的临时文件名 
 
$request_completion 当请求已经全部完成时,其值为 “ok”。若没有完成,就要返回客户端,则其值为空字符串;或者在断点续传等情况下使用 HTTP range访问的并不是文件的最后一块,那么其值也是空字符串。
 
$request_method 表示 HTTP请求的方法名,如 GET、PUT、POST等 
 
$scheme 表示 HTTP scheme,如在请求 https://nginx.com/中表示 https 
 
$server_addr 表示服务器地址 
$server_name 表示服务器名称 
$server_port 表示服务器端口 
 
$server_protocol 表示服务器向客户端发送响应的协议,如 HTTP/1.1或 HTTP/1.
 
$remote_addr, $http_x_forwarded_for 记录客户端IP地址
 
$remote_user 记录客户端用户名称
 
$request 记录请求的URL和HTTP协议
 
$status 记录请求状态
 
$body_bytes_sent 发送给客户端的字节数,不包括响应头的大小; 该变量与Apache模块mod_log_config里的“%B”参数兼容。
 
$bytes_sent 发送给客户端的总字节数。
 
$connection 连接的序列号。
 
$connection_requests 当前通过一个连接获得的请求数量。
 
$msec 日志写入时间。单位为秒,精度是毫秒。
 
$pipe 如果请求是通过HTTP流水线(pipelined)发送,pipe值为“p”,否则为“.”。
 
$http_referer 记录从哪个页面链接访问过来的
 
$http_user_agent 记录客户端浏览器相关信息
 
$request_length 请求的长度(包括请求行,请求头和请求正文)。
 
$request_time 请求处理时间,单位为秒,精度毫秒; 从读入客户端的第一个字节开始,直到把最后一个字符发送给客户端后进行日志写入为止。
 
$time_iso8601 ISO8601标准格式下的本地时间。
 
$time_local 通用日志格式下的本地时间。

以上只是部分解释,用到什么再到网上查找。下面教大家如何配置。

首先,安装nginx。修改主配置文件 nginx.onf

user  nginx;
worker_processes  auto;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main#定义日志格式的名称,叫什么也行。  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"'
		      '$upstream_addr $upstream_response_time '
		      '$request_time';
    access_log  /var/log/nginx/access.log  main#引用日志格式;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}

不是只有主配置文件里可以引用该日志格式,只要是nginx的配置文(包括子配置文件)件都可以引用这个日志格式。
include /etc/nginx/conf.d/*.conf;只要在nginx里的主配置文件定义了,这个目录下都可以引用。

下图是生成环境中配置的负载均衡的截图。请根据自己的实际应用场景进行修改。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值