广告
返回顶部
首页 > 资讯 > 精选 >如何配置Nginx访问与错误日志
  • 922
分享到

如何配置Nginx访问与错误日志

2023-06-30 16:06:05 922人浏览 八月长安
摘要

这篇“如何配置Nginx访问与错误日志”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何配置Nginx访问与错误日志”文章吧

这篇“如何配置Nginx访问与错误日志”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何配置Nginx访问与错误日志”文章吧。

Nginx是一个开放源代码的高性能Http和反向代理服务器,负责处理Internet上某些最大站点的负载。在管理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 参数设置日志记录级别。以下是按严重性从低到高列出的级别:

debuginfonoticewarnerrorcritalertemerg

每个日志级别包括更高级别。例如,如果你将日志级别设置为 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发行版中,例如ubuntuCentos和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访问与错误日志”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: 如何配置Nginx访问与错误日志

本文链接: https://www.lsjlt.com/news/330067.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何配置Nginx访问与错误日志
    这篇“如何配置Nginx访问与错误日志”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何配置Nginx访问与错误日志”文章吧...
    99+
    2023-06-30
  • 聊聊配置 Nginx 访问与错误日志的问题
    目录配置Nginx访问日志配置错误日志日志文件的位置读取和理解Nginx日志文件Nginx是一个开放源代码的高性能HTTP和反向代理服务器,负责处理Internet上某些最大站点的负...
    99+
    2022-11-13
  • php.ini如何配置错误日志
    这篇文章主要介绍“php.ini如何配置错误日志”,在日常操作中,相信很多人在php.ini如何配置错误日志问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php.ini如何配置错误日志”的疑惑有所帮助!接下来...
    99+
    2023-06-20
  • Apache访问日志的配置与使用
    我们使用的是/usr/local/apache2.4/conf/extra/httpd-vhosts.conf配置文件下的第二段配置,它的日志在/usr/local/apache2.4/logs/下面 #cat ...
    99+
    2022-06-04
    apache 配置访问日志 apache 访问日志 Apache日志配置
  • Nginx日志格式如何配置
    本篇内容主要讲解“Nginx日志格式如何配置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Nginx日志格式如何配置”吧!上线了一个小的预约程序,配置通过Nginx进行访问入口,默认的日志是没有...
    99+
    2023-07-05
  • PHP错误日志如何配置和使用
    小编给大家分享一下PHP错误日志如何配置和使用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!对于 PHP 开发者来说,一旦某个项目投入使用,应该立即将配置文件 p...
    99+
    2023-06-25
  • php如何设置错误日志
    这篇文章主要讲解了“php如何设置错误日志”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php如何设置错误日志”吧!设置方法:打开php.ini文件,设置“error_reporting=E...
    99+
    2023-06-20
  • nginx中如何输出php错误日志文件
    这篇文章主要介绍“nginx中如何输出php错误日志文件”,在日常操作中,相信很多人在nginx中如何输出php错误日志文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”nginx中如何输出php错误日志文件...
    99+
    2023-07-05
  • 一文详细介绍查看和启用nginx日志(access.log和error.log),nginx错误日志的安全级别,自定义访问日志中的格式
    文章目录 1. 文章引言 2. Nginx访问日志(access.log) 2.1 简述访问日志 2.2 启用Nginx访问日志 2.3 自定义访问日志中的格式 3. Nginx错误日志(...
    99+
    2023-08-30
    nginx 运维 服务器 后端 运维开发
  • Nginx本地如何配置SSL访问
    这篇文章主要介绍“Nginx本地如何配置SSL访问”,在日常操作中,相信很多人在Nginx本地如何配置SSL访问问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Nginx本地如何配置SSL访问”的疑惑有所帮助!...
    99+
    2023-06-30
  • SpringBoot如何解决配置SwaggerUI访问404错误的问题
    这篇文章将为大家详细讲解有关SpringBoot如何解决配置SwaggerUI访问404错误的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。SpringBoot 配置SwaggerUI 访问404的小...
    99+
    2023-05-30
    springboot swaggerui 404
  • 解决Druid动态数据源配置重复刷错误日志的问题
    Druid动态数据源配置 主要是继承AbstractRoutingDataSource再通过AOP来实现动态数据源切换. 下面给大家介绍Druid动态配置数据源重复刷错误日志问题,具...
    99+
    2022-11-12
  • 如何使用Nginx纯配置实现日志实时上报
    这篇文章主要为大家展示了“如何使用Nginx纯配置实现日志实时上报”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Nginx纯配置实现日志实时上报”这篇文章吧。前言Nginx 作为常用的负...
    99+
    2023-06-22
  • nginx日志报警|微信公众号推送预警消息|PHP+shell脚本实现nginx错误日志报警&恶意访问报警,实时通知到微信公众号 | 小型网站nginx日志报警轻量级方案
    1、shell脚本 命名:run.sh #!/bin/bash #!/usr/bin/python# -*- coding:utf-8 -*-#日志文件路径 accesslog=/www/wwwlogs/...
    99+
    2023-09-05
    nginx 微信公众平台 linux 自动化 php
  • 如何配置CentOS系统以限制用户对系统日志的访问权限
    要限制用户对系统日志的访问权限,您可以按照以下步骤配置CentOS系统:1. 打开终端并以root用户身份登录。2. 编辑 `/et...
    99+
    2023-10-12
    CentOS
  • Laravel与Vue Nginx配置的常见问题如何解决
    这篇文章主要讲解了“Laravel与Vue Nginx配置的常见问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Laravel与Vue Nginx配置的常见问题如何解决”吧!Lar...
    99+
    2023-07-04
  • ASP 日志框架 path:如何解决常见的问题和错误?
    在 ASP.NET 开发中,日志框架是非常重要的一部分。日志框架可以帮助开发者更好地跟踪代码中的错误和问题,并快速解决这些问题。ASP 日志框架 path 是一款常用的日志框架,本文将介绍如何解决 path 日志框架中的常见问题和错误。 ...
    99+
    2023-09-27
    日志 框架 path
  • linux系统中如何配置Nginx 拒绝代理访问指定IP
    这篇文章主要介绍“linux系统中如何配置Nginx 拒绝代理访问指定IP”,在日常操作中,相信很多人在linux系统中如何配置Nginx 拒绝代理访问指定IP问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”l...
    99+
    2023-06-13
  • 如何理解shell脚本nginx日志访问次数最多及最耗时的页面
    本篇内容介绍了“如何理解shell脚本nginx日志访问次数最多及最耗时的页面”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!当服务器压力比较...
    99+
    2023-06-09
  • ​如何设置SQL Server中错误日志的最大归档数量
    这篇文章给大家分享的是有关如何设置SQL Server中错误日志的最大归档数量的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 如何设置SQL Server的错误日志的最大归档数量...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作