创作

完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>

3天内不再提示

配置Nginx访问日志

magedu-Linux 来源:入门小站 作者:入门小站 2022-05-24 09:59 次阅读

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

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

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

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

配置Nginx访问日志

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

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

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


	

access_loglog_filelog_format;

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

默认情况下,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_namedomain.com access_log/var/log/nginx/domain.access.log; ... } }

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

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


	

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

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


	

log_formatcustom'$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.logcustom;

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

access_log off;

配置错误日志

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

	
		error_loglog_filelog_levellog_level参数设置日志记录级别。以下是按严重性从低到高列出的级别:
  • debug-调试消息。
  • info-信息性消息。
  • notice-公告。
  • warn- 警告。
  • error-处理请求时出错。
  • crit-关键问题。需要立即采取行动。
  • alert-警报。必须立即采取行动。
  • emerg- 紧急情况。系统处于无法使用的状态。
每个日志级别包括更高级别。例如,如果你将日志级别设置为warn,则Nginx还将记录errorcritalertemerg消息。未指定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_namedomain.com error_log/var/log/nginx/domain.error.logwarn; ... } }
		无论何时修改配置文件,都必须重新加载Nginx服务,以使更改生效。

日志文件的位置

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

读取和理解Nginx日志文件

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

	
		192.168.33.1--[15/Oct/201941:46+0000]"GET/HTTP/1"200396"-""Mozilla/0(X11;Linuxx86_64)AppleWebKit/536(KHTML,likeGecko)Chrome/38120Safari/536"
		让我们细分Nginx日志文件记录的每个字段意味着什么:
  • $remote_addr-192.168.33.1-发出请求的客户端的IP地址。
  • $remote_user---HTTP身份验证用户。未设置用户名时,此字段显示-
  • [$time_local]-[15/Oct/201941: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

审核编辑 :李倩


  • 服务器
    +关注

    关注

    10

    文章

    4389

    浏览量

    75723
  • 源代码
    +关注

    关注

    68

    文章

    2759

    浏览量

    61749
  • nginx
    +关注

    关注

    0

    文章

    46

    浏览量

    10593

原文标题:配置 Nginx 访问与错误日志

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    从SmartNIC走向DPU,专用加速器的崛起

    在计算架构和负载变得愈发复杂和多样的情况下,处理器厂商纷纷开始了自己的造词之路。要想体现产品定位,又....
    的头像 E4Life 发表于 06-25 01:17 365次 阅读
    从SmartNIC走向DPU,专用加速器的崛起

    IEEE标准推进工业4.0的五种方式

      毫无疑问,TSN 标准是承诺工业 4.0 及其将改变的许多应用的关键基础构件——引领下一代技术彻....
    的头像 星星科技指导员 发表于 06-24 16:00 301次 阅读

    TYAN在1U封装中包含大量性能

    这是一个 1U 服务器,采用单插槽 Intel Xeon E-2200 微处理器设计。作为基于边缘的....
    的头像 星星科技指导员 发表于 06-24 14:57 72次 阅读

    5G移动网络边缘部署应用服务器

      MEC是5G网络拓扑皇冠上的皇冠上的明珠。激励措施是真实的,新的商业模式和收入流是一个巨大的驱动....
    的头像 星星科技指导员 发表于 06-24 14:33 114次 阅读

    曙光StackCube-K超融合云平台助力用户打造特色政务服务

    滚滚湘江水,悠悠进取心。左脚根植于井冈山革命根据地,右脚立足在数字化发展的潮头,湖南省某县自然资源局....
    的头像 科技绿洲 发表于 06-24 14:23 95次 阅读

    低功耗蓝牙在低功耗设计中的应用

      随着4.0版本支持的低功耗蓝牙(BLE)的出现,由于消费市场对低能耗和低功耗的需求(BLE由Bl....
    的头像 星星科技指导员 发表于 06-24 11:26 118次 阅读
    低功耗蓝牙在低功耗设计中的应用

    边缘的超低功耗关键短语检测

      BNN 可以检测多达十个 1 秒的关键短语,非常适合通过语音进行 HMI。为了提高检测精度,仅在....
    的头像 星星科技指导员 发表于 06-24 10:09 233次 阅读
    边缘的超低功耗关键短语检测

    网络时钟安装及调试的详细说明

    针对于各大医院里的医疗设备及医生办公设备的时间需要统一,在医院内提供一套可靠、经济和有效,能够提供一....
    的头像 syn029 发表于 06-24 09:11 110次 阅读

    免费vps试用7天和免费vps试用30天有何区别

    我们在租用vps的时候,经常会发现很多主机商比如恒讯科技会提供3-30天不等的免费vps试用机会,其....
    的头像 深圳市恒讯科技有限公司 发表于 06-23 16:06 33次 阅读

    Robox安卓容器的构建编译过程和使用方法

    随着云计算相关产业蓬勃发展,用户对移动设备的弹性需求推动出云手机、云游戏等概念,云手机和云游戏就是将....
    的头像 安芯教育科技 发表于 06-23 15:51 145次 阅读

    麒麟软件与openEuler社区合作打造行业应用标杆案例

    首届“华为伙伴暨开发者大会”于6月在线召开,华为公司副总裁、计算产品线总裁邓泰华发表“共建计算产业,....
    的头像 科技绿洲 发表于 06-23 14:37 195次 阅读

    液冷散热的方式有哪些 液体冷却的优点与误区

    随着计算能力和性能需求的提高,AI人工智能、物联网和机器学习等技术进步,数据中心基础设施和IT设备的....
    的头像 GPU视觉识别 发表于 06-23 11:58 195次 阅读

    视频质量网络测试改善用户体验

      VQ 测试工具与来自人类视觉 VQ 调查等测试场景的最终用户反馈相结合,可以帮助企业提高视频会议....
    的头像 星星科技指导员 发表于 06-23 11:06 147次 阅读
    视频质量网络测试改善用户体验

    基于云的M2M管理的竞争优势

      端到端 M2M 管理服务为具有 M2M 部署的公司提供了一种可行的、经过验证的解决方案,该解决方....
    的头像 星星科技指导员 发表于 06-23 10:25 96次 阅读
    基于云的M2M管理的竞争优势

    设计人员在实施M2M功能时面临的挑战

      虽然 M2M 开发人员可以轻松编写自己的服务例程并通过简单的系统调用从程序中访问它们,但 And....
    的头像 星星科技指导员 发表于 06-23 10:22 95次 阅读
    设计人员在实施M2M功能时面临的挑战

    mongols C++服务器基础设施

    ./oschina_soft/mongols.zip
    发表于 06-23 10:15 4次 阅读
    mongols C++服务器基础设施

    基于Cocos2d-X 3.17与cocostudio V3.10开发的单机麻将游戏

    ./oschina_soft/gitee-cocostudio-mahjong.zip
    发表于 06-23 10:06 4次 阅读
    基于Cocos2d-X 3.17与cocostudio V3.10开发的单机麻将游戏

    直播视频流服务器解决方案简介

    由于全球流媒体规模,到2025年,全球视频流媒体行业预计将达到每年 1245.7 亿美元。平均消费者....
    的头像 深圳市恒讯科技有限公司 发表于 06-22 16:39 155次 阅读

    具有固定优先级调度程序RTOS的优先级倒置

      优先级继承并不能真正治愈优先级倒置,它只是在某些情况下将其影响最小化。硬实时应用程序仍应仔细设计....
    的头像 星星科技指导员 发表于 06-22 15:45 152次 阅读
    具有固定优先级调度程序RTOS的优先级倒置

    液晶显示的源代码

    液晶显示的keil源代码
    发表于 06-22 15:14 8次 阅读

    Dragonboat Go实现的多组Raft库

    ./oschina_soft/dragonboat.zip
    发表于 06-22 15:03 5次 阅读
    Dragonboat Go实现的多组Raft库

    用于管理流量和启用SDN编排的协议

      然而,这并不是镇上唯一的游戏。思科已将 OpFlex 作为其以应用程序为中心的基础设施 (ACI....
    的头像 星星科技指导员 发表于 06-22 15:00 95次 阅读

    时钟服务器在医院HIS系统的应用

    针对于各大医院里的医疗设备及医生办公设备的时间需要统一,在医院内提供一套可靠、经济和有效,能够提供一....
    的头像 syn029 发表于 06-22 14:58 87次 阅读
    时钟服务器在医院HIS系统的应用

    基于Linux的物联网设备的安全案例

      对于物联网产品,在设计之初就将安全性构建到产品中是绝对必要的。如果您不这样做,您的业务的关键部分....
    的头像 星星科技指导员 发表于 06-22 14:28 66次 阅读

    利用Yocto/OpenEmbedded进行嵌入式软件部署

      更进一步,可以将元产品层合并到初始的 Yocto/OpenEmbedded 设置过程中,例如在我....
    的头像 星星科技指导员 发表于 06-22 14:05 99次 阅读

    简化SBC的嵌入式Linux软件开发

      在 Eclipse 框架内,EMAC 使用交叉编译来缓解将嵌入式开发环境从标准桌面环境中抽象出来....
    的头像 星星科技指导员 发表于 06-22 11:48 121次 阅读
    简化SBC的嵌入式Linux软件开发

    Fist轻量级全文索引/搜索服务器

    ./oschina_soft/fist.zip
    发表于 06-22 11:28 8次 阅读
    Fist轻量级全文索引/搜索服务器

    迈向混合关键实时服务器市场

    康佳特推出五款新COM-HPC Server Size D模块,搭载遵循“紧凑高效”理念的英特尔至强....
    发表于 06-22 10:52 208次 阅读
    迈向混合关键实时服务器市场

    TarsCpp Tars RPC框架C++语言的源代码

    ./oschina_soft/gitee-TarsCpp.zip
    发表于 06-22 10:17 8次 阅读
    TarsCpp Tars RPC框架C++语言的源代码

    物理机服务器有什么用?

    首先我们先了解物理机是由什么部分组成:主板、内存、硬盘、阵列卡、电源、网卡、风扇。tg@CDNJSFY 另外物理机服务器有几...
    发表于 06-22 10:16 818次 阅读
    物理机服务器有什么用?

    ctsTraffic网络性能和可靠性分析工具

    ./oschina_soft/ctsTraffic.zip
    发表于 06-22 10:14 6次 阅读
    ctsTraffic网络性能和可靠性分析工具

    InspIRCd模块化C++ IRC守护进程

    ./oschina_soft/inspircd.zip
    发表于 06-22 10:03 8次 阅读
    InspIRCd模块化C++ IRC守护进程

    tinyserver C++编写的轻量服务器框架

    ./oschina_soft/tinyserver.zip
    发表于 06-22 09:53 6次 阅读
    tinyserver C++编写的轻量服务器框架

    FBGEMM服务器端推理优化库

    ./oschina_soft/FBGEMM.zip
    发表于 06-22 09:27 6次 阅读
    FBGEMM服务器端推理优化库

    时钟同步系统在银行系统的应用

    银行系统的时钟同步系统的目的是为银行内部系统装上统一的时间标尺,从整体的角度再次审视信息系统生态的时....
    的头像 syn029 发表于 06-22 09:17 141次 阅读

    美光与AMD携手为下一代数据中心提供更强计算性能

    目前数据中心容纳了全球约三分之一的数据。2020年的数据量大约是20ZB,预计到2025年都将保持1....
    的头像 科技绿洲 发表于 06-21 17:16 362次 阅读

    使用NVIDIA Clara Parabricks 3.8加速基因组分析

      与基于CPU的环境相比,最先进的生物信息学工具的速度提高了60倍。全基因组工作流程的端到端分析只....
    的头像 星星科技指导员 发表于 06-21 15:23 101次 阅读
    使用NVIDIA Clara Parabricks 3.8加速基因组分析

    GW-BASIC BASIC的方言版本

    ./oschina_soft/GW-BASIC.zip
    发表于 06-21 11:56 12次 阅读
    GW-BASIC BASIC的方言版本

    DwScore演讲比赛评委打分系统

    ./oschina_soft/gitee-DwScore.zip
    发表于 06-21 11:35 4次 阅读
    DwScore演讲比赛评委打分系统

    WLAN网络帮助自动化订单拣选过程

      持续的流程改进要求以具有成本效益的方式来解决棘手的供应链管理问题。安全和强大的 WLAN 网络正....
    的头像 星星科技指导员 发表于 06-21 11:27 177次 阅读

    中科曙光用AI为崂山注入新活力

    作为青岛最“年轻”的主城区,崂山深谙发展之道。在决战数字经济与实体经济深度融合的过程中,紧紧抓住产业....
    的头像 科技绿洲 发表于 06-21 11:14 339次 阅读

    如何使用PCIe5.0/6.0 PHY IP在数据中心存储设计中实现U.2/U.3连接

    系统公司在设计服务器时面临的一个主要挑战,是升级存储架构以满足当前和未来的数据中心要求。这些升级包括....
    的头像 科技绿洲 发表于 06-21 11:05 215次 阅读
    如何使用PCIe5.0/6.0 PHY IP在数据中心存储设计中实现U.2/U.3连接

    OpenMediation移动广告聚合平台

    ./oschina_soft/OpenMediation.zip
    发表于 06-21 11:00 6次 阅读
    OpenMediation移动广告聚合平台

    Paddle Serving飞桨服务器端部署库

    ./oschina_soft/gitee-Serving.zip
    发表于 06-21 10:12 6次 阅读
    Paddle Serving飞桨服务器端部署库

    Pixman像素处理的底层软件库

    ./oschina_soft/pixman.zip
    发表于 06-21 09:34 6次 阅读
    Pixman像素处理的底层软件库

    objtrace使用方法与代码分析

    我们在内核代码调试过程中,经常会遇到需要跟踪函数参数值变化的情况,objtrace是一个非常有创造性....
    的头像 Linux阅码场 发表于 06-21 09:08 74次 阅读

    如何保护嵌入式系统免受量子启示录的影响

      迁移到新的加密算法和 PKI 系统将需要颁发大量新证书,因为每个设备/应用程序都需要一个新证书。....
    的头像 星星科技指导员 发表于 06-20 14:28 143次 阅读
    如何保护嵌入式系统免受量子启示录的影响

    蓝牙无线技术产品都需遵循蓝牙SIG管理认证过程

      随着4.0版本支持的低功耗蓝牙(BLE)的出现,由于消费市场对低能耗和低功耗的需求(BLE由Bl....
    的头像 星星科技指导员 发表于 06-20 10:41 195次 阅读
    蓝牙无线技术产品都需遵循蓝牙SIG管理认证过程

    开源软件-Sogou C++ Workflow高性能C++服务器引擎

    ./oschina_soft/gitee-workflow.zip
    发表于 06-20 09:36 7次 阅读
    开源软件-Sogou C++ Workflow高性能C++服务器引擎

    开源软件-smart_rtmpd rtmp、rtsp服务器

    ./oschina_soft/smart_rtmpd.zip
    发表于 06-20 09:24 17次 阅读
    开源软件-smart_rtmpd rtmp、rtsp服务器

    基于Select/Poll实现并发服务器(二)

    开发环境: RT-Thread版本:4.0.3 操作系统:Windows10 Keil版本:V5.3....
    的头像 嵌入式大杂烩 发表于 06-20 00:26 1857次 阅读
    基于Select/Poll实现并发服务器(二)

    将Arm架构代码从X86服务器迁移到aarch64服务器上实战分享

    1、Arm架构代码移植实战分享编程语言简介按照翻译方式的不同,高级语言通常可以分为两类:一类是编译翻译,一类是解释翻译,分别...
    发表于 06-02 17:04 5384次 阅读

    为什么要在OpenHarmony设备上安装Dropbear呢

    ssh是一个常见的、可靠的远程终端/文件传输的协议,OpenHarmony本身并没有ssh服务器的功能。 为了启用ssh功能,我们需要引入一...
    发表于 05-23 17:45 1869次 阅读

    HTTP OTA webclient获取不到服务器如何处理?

    尝试用HTTP_OTA的方式来升级程序,按照网上的资料搭建程序,在http_ota.c中现在遇到Webclient获取不到服务器的情况: ...
    发表于 05-19 10:43 1248次 阅读

    自己上传的工程无法在线查看

    是服务器问题吗 一直提示无法下载
    发表于 05-17 14:25 3903次 阅读
    自己上传的工程无法在线查看

    影响服务器访问速度的因素

    我们在租用服务器的过程中,可能在访问速度方面,会受到某些因素影响,如果您要进行此项业务,进行一些简单的了解是非常的有必要...
    发表于 05-17 09:50 4229次 阅读

    kawayi mqtt连接mosquitto始终连接不上怎么解决?

    各位大咖好,遇到难点了,求助! 之前用lwip+phy调试和pc互ping没问题,现在在此基础上增加了kawayi mqtt软件包,尝试连接创建的...
    发表于 05-06 09:50 1658次 阅读

    为什么ARMv8的通用服务器是ACPI呢

    overview ACPI可以用于ARMv8通用服务器,设计遵循ARM的SBSA (Server Base System Architecture) 和SBBR ...
    发表于 04-21 09:48 2429次 阅读

    DevEco Device Tool对开发板HI3861的源代码进行编译时报错如何解决?

    我在DevEco Device Tool中按照华为官网的 鸿蒙文档对开发板HI3861(windows环境下)的源代码进行编译时报错,求各位大佬帮...
    发表于 04-18 11:10 1391次 阅读

    求一份基于RK3399的Samba共享服务器设计方案

    1、搭建Samba共享服务器安装Samba首先远程登陆 RK3399 执行以下命令安装 Samba 安装结束阶段有错误提示,但提示说可以忽略...
    发表于 04-15 16:10 3135次 阅读