聊聊配置 Nginx 访问与错误日志的问题


Posted in Servers onMay 25, 2022

Nginx是一个开放源代码的高性能HTTP和反向代理服务器,负责处理Internet上某些最大站点的负载。在管理NGINX网络服务器时,你要执行的最常见任务之一就是检查日志文件。

在对服务器或应用程序问题进行故障排除时,知道如何配置和读取日志非常有用,因为它们提供了详细的调试信息。

Nginx用两种类型的日志记录其事件:访问日志和错误日志。访问日志记录有关客户端请求的信息,错误日志记录有关服务器和应用程序问题的信息。

本教程概述了如何配置和读取Nginx访问和错误日志。配置Nginx访问日志的格式与位置,配置错误日志格式与位置,默认的日志文件所在位置,读取和理解Nginx日志文件每个字段。

配置Nginx访问日志

每当处理客户请求时,Nginx都会在访问日志中生成一个新记录。每个事件记录都包含一个时间戳,并包含有关客户端和所请求资源的各种信息。访问日志可以显示访问者的位置,访问者的访问的页面等。

log_format 指令允许你定义记录日志的格式。 access_log 指令启用并设置日志文件的位置和使用的格式。

access_log 指令的最基本语法如下:

access_log log_file log_format;

其中 log_file 是日志文件的完整路径, log_format 是日志文件使用的格式。可以在 http , server 或 location 指令的上下文中启用访问日志。

默认情况下,Nginx主配置文件中的 http 指令配置了全局访问日志格式。

http {
  ...
  access_log  /var/log/nginx/access.log;
  ...
}

/etc/nginx/nginx.conf

为获得更好的可维护性,建议为每个服务器设置一个单独的访问日志文件。在 server 指令中设置的 access_log 指令将覆盖在 http 指令中设置的 access_log 。

http {
  ...
  access_log  /var/log/nginx/access.log;
  ...
  server {
    server_name domain.com
    access_log  /var/log/nginx/domain.access.log;
    ...
  }
}

/etc/nginx/conf.d/domain.com.conf

如果未指定日志格式,Nginx将使用预定义的combined组合格式,如下所示:

log_format combined '$remote_addr - $remote_user [$time_local] '
                    '"$request" $status $body_bytes_sent '
                    '"$http_referer" "$http_user_agent"';

要更改日志记录格式,请覆盖默认设置或定义一个新设置。例如,定义一个名为 main 的新日志记录格式,它将用添加 X-Forwarded-For header的值来扩展 combined 格式,在 http 或 server 中添加以下定义指令:

log_format  custom  '$remote_addr - $remote_user [$time_local] "$request" '
                    '$status $body_bytes_sent "$http_referer" '
                    '"$http_user_agent" "$http_x_forwarded_for"';

要使用新日志格式,请在日志文件后指定其名称,如下所示:

access_log  /var/log/nginx/access.log custom;

虽然访问日志提供了非常有用的信息。但它会占用磁盘空间,并可能影响服务器性能。如果服务器资源不足,并且网站繁忙,则可能要禁用访问日志。为此,请将 access_log 伪指令的值设置为 off 。理论上你不会出现这种情况,Nginx会自动删除前期的日志文件:

access_log off;

配置错误日志

Nginx将应用程序和常规服务器错误的消息写入错误日志文件。如果你在Web应用程序中遇到错误,则错误日志是你开始进行排查问题的第一个位置。 error_log 指令启用并设置错误日志的位置和严重性级别。它采用以下格式,可以在 http , server 或 location 上下文中进行设置:

error_log log_file log_level

log_level 参数设置日志记录级别。以下是按严重性从低到高列出的级别:

debug
info
notice
warn
error
crit
alert
emerg

每个日志级别包括更高级别。例如,如果你将日志级别设置为 warn ,则Nginx还将记录 error , crit , alert 和 emerg 消息。未指定 log_level 参数时,默认为 error 。默认情况下, error_log 指令在主nginx.conf文件内的 http 指令上下文中定义:

http {
  ...
  error_log  /var/log/nginx/error.log;
  ...
}

/etc/nginx/nginx.conf与访问日志相同,建议为每个服务器设置一个单独的错误日志文件,该文件将覆盖更高级别的设置如http指令上下文。例如,要将domain.com的错误日志设置为 warn ,你可以使用:

http {
  ...
  error_log  /var/log/nginx/error.log;
  ...

  server {
    server_name domain.com
    error_log  /var/log/nginx/domain.error.log warn;
    ...
  }
}

无论何时修改配置文件,都必须重新加载Nginx服务,以使更改生效。

日志文件的位置

在大多数Linux发行版中,例如Ubuntu ,CentOS和Debian。默认情况下,访问和错误日志位于 /var/log/nginx 目录中。

读取和理解Nginx日志文件

你可以使用 cat , less , grep , cut , awk 等命令打开和解析nginx日志文件。以下是使用默认的Nginx日志格式的访问日志文件的记录:

192.168.33.1 - - [15/Oct/2019:19:41:46 +0000] "GET / HTTP/1" 200 396 "-" "Mozilla/0 (X11; Linux x86_64) AppleWebKit/536 (KHTML, like Gecko) Chrome/38120 Safari/536"

让我们细分Nginx日志文件记录的每个字段意味着什么:

  • $remote_addr – 192.168.33.1 -发出请求的客户端的IP地址。
  • $remote_user  – - -HTTP身份验证用户。未设置用户名时,此字段显示 - 。
  • [$time_local] – [15/Oct/2019:19:41:46 +0000]

本地服务器时间。

  • "$request"  – "GET / HTTP/1.1" -请求类型,路径和协议。
  • $status  – 200 -服务器响应代码。
  • $body_bytes_sent  – 396 -服务器响应的大小(以字节为单位)。
  • "$http_referer"  – "-" -引荐网址。
  • "$http_user_agent"  – Mozilla/5.0 ... -客户端的用户代理(网络浏览器)。

使用 tail 命令实时观看日志文件记录: tail -f access.log

到此这篇关于配置 Nginx 访问与错误日志的文章就介绍到这了!


Tags in this post...

Servers 相关文章推荐
Nginx同一个域名配置多个项目的实现方法
Mar 31 Servers
Nginx配置并兼容HTTP实现代码解析
Mar 31 Servers
详解nginx.conf 中 root 目录设置问题
Apr 01 Servers
nginx中封禁ip和允许内网ip访问的实现示例
Mar 17 Servers
Nginx流量拷贝ngx_http_mirror_module模块使用方法详解
Apr 07 Servers
阿里云k8s服务升级时502错误 springboot项目应用
Apr 09 Servers
配置nginx负载均衡
May 06 Servers
详解Nginx的超时keeplive_timeout配置步骤
May 25 Servers
nginx设置资源请求目录的方式详解
May 30 Servers
Nginx本地配置SSL访问的实例教程
May 30 Servers
Windows Server 2022 超融合部署(图文教程)
Jun 25 Servers
vscode远程免密登入Linux服务器的配置方法
Jun 28 Servers
利用nginx搭建RTMP视频点播、直播、HLS服务器
详解Nginx的超时keeplive_timeout配置步骤
May 25 #Servers
nginx 配置指令之location使用详解
May 25 #Servers
zabbix配置nginx监控的实现
May 25 #Servers
nginx 添加http_stub_status_module模块
May 25 #Servers
docker 制作mysql镜像并自动安装
May 20 #Servers
阿里云服务器Ubuntu 20.04上安装Odoo 15
May 20 #Servers
You might like
php 正则 过滤html 的超链接
2009/06/02 PHP
PHP实现视频文件上传完整实例
2014/08/28 PHP
android上传图片到PHP的过程详解
2015/08/03 PHP
php lcg_value与mt_rand生成0~1随机小数的效果对比分析
2017/04/05 PHP
phpStudy 2016 使用教程详解(支持PHP7)
2017/10/18 PHP
laravel框架实现去掉URL中index.php的方法
2019/10/12 PHP
js玩一玩WSH吧
2007/02/23 Javascript
TextArea 控件的最大长度问题(js json)
2009/12/16 Javascript
javascript使用正则表达式检测IP地址
2014/12/03 Javascript
jQuery 重复加载错误以及修复方法
2014/12/16 Javascript
JS获得图片alt信息的方法
2015/04/01 Javascript
jquery实现的动态回到顶部特效代码
2015/10/28 Javascript
javascript实现仿百度图片的瀑布流加载效果
2016/04/20 Javascript
从零开始学习Node.js系列教程六:EventEmitter发送和接收事件的方法示例
2017/04/13 Javascript
JS写谷歌浏览器chrome的外挂实例
2018/01/11 Javascript
Swiper.js实现移动端元素左右滑动
2019/09/08 Javascript
详解Typescript 内置的模块导入兼容方式
2020/05/31 Javascript
Python列表计数及插入实例
2014/12/17 Python
使用Python实现下载网易云音乐的高清MV
2015/03/16 Python
Python中的深拷贝和浅拷贝详解
2015/06/03 Python
Python使用cookielib模块操作cookie的实例教程
2016/07/12 Python
Python3 使用pillow库生成随机验证码
2019/08/26 Python
Tensorflow读取并输出已保存模型的权重数值方式
2020/01/04 Python
JetBrains PyCharm(Community版本)的下载、安装和初步使用图文教程详解
2020/03/19 Python
python如何输出反斜杠
2020/06/18 Python
python工具——Mimesis的简单使用教程
2021/01/16 Python
6种非常炫酷的CSS3按钮边框动画特效
2016/03/16 HTML / CSS
css3 利用transform打造走动的2D时钟
2020/10/20 HTML / CSS
Android面试题附答案
2014/12/08 面试题
女子职高个人自荐书
2014/02/01 职场文书
2014年教务工作总结
2014/12/03 职场文书
清洁工个人工作总结
2015/03/05 职场文书
事业单位财务人员岗位职责
2015/04/14 职场文书
2015年初中教务处工作总结
2015/07/21 职场文书
教你使用Pandas直接核算Excel中快递费用
2021/05/12 Python
Java 超详细讲解ThreadLocal类的使用
2022/04/07 Java/Android