nginx访问日志,错误日志参数说明
说明:
nginx日志主要有两种:访问日志、错误日志。其中访问日志记录客户端访问nginx的每一个请求,包含用户地域来源、跳转来源、使用终端、某个URL访问量等信息,访问日志格式可以自定义;错误日志则记录客户端访问nginx出错时的日志,格式不支持自定义,通过错误日志,你可以得到系统某个服务或server的性能瓶颈等。两种日志都可以选择性关闭。
访问日志[Access.log]
log_format  main  ‘$remote_addr $remote_user [$time_local] “$request” $http_host ‘
‘$status $upstream_status $body_bytes_sent “$http_referer” ‘
‘”$http_user_agent” $ssl_protocol $ssl_cipher $upstream_addr ‘
‘$request_time $upstream_response_time’;
| 变量名称 | 变量描述 | 举例说明 | 
| $remote_addr | 客户端地址 | 113.140.15.90 | 
| $remote_user | 客户端用户名称 | – | 
| $time_local | 访问时间和时区 | 18/Jul/2012:17:00:01 +0800 | 
| $request | 请求的URI和HTTP协议 | “GET /pa/img/home/logo-alipay-t.png HTTP/1.1” | 
| $http_host | 请求地址,即浏览器中你输入的地址(IP或域名) | img.alipay.com 10.253.70.103 | 
| $status | HTTP请求状态 | 200 | 
| $upstream_status | upstream状态 | 200 | 
| $body_bytes_sent | 发送给客户端文件内容大小 | 547 | 
| $http_referer | 跳转来源 | “https://cashier.alipay.com…/” | 
| $http_user_agent | 用户终端代理 | “Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; SV1; GTB7.0; .NET4.0C; | 
| $ssl_protocol | SSL协议版本 | TLSv1 | 
| $ssl_cipher | 交换数据中的算法 | RC4-SHA | 
| $upstream_addr | 后台upstream的地址,即真正提供服务的主机地址 | 10.228.35.247:80 | 
| $request_time | 整个请求的总时间 | 0.205 | 
| $upstream_response_time | 请求过程中,upstream响应时间 | 0.002 | 
线上实例:
116.9.137.90 – [02/Aug/2012:14:47:12 +0800] “GET
/images/XX/20100324752729.png HTTP/1.1″img.alipay.com 200 200 2038
https://cashier.alipay.com/XX/PaymentResult.htm?payNo=XX&outBizNo=2012XX
 “Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/4.0; SLCC2;
 .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media
Center PC 6.0; Tablet PC 2.0; 360SE)” TLSv1 AES128-SHA 10.228.21.237:80
0.198 0.001
线下测试($http_referer):
10.14.21.197 – – [14/Aug/2012:17:28:22 +0800] “GET
/spanner/watch/v1?–db=ztg-1&–mode=compare&–index=status&–option=&–cluster=whole&-F=2012%2F8%2F12-00%3A00%3A00&-T=%2B2880&-i=1&-n=0&_=1344936501292
 HTTP/1.1” 200 94193
“http://spanner.alipay.net/optionFrame/history.html” “Mozilla/5.0
(Windows NT 6.1) AppleWebKit/537.1 (KHTML, like Gecko)
Chrome/21.0.1180.60 Safari/537.1”

备注:$http_referer和重定向有关。
错误日志[Error.log]
| 错误信息 | 错误说明 | 
| “upstream prematurely(过早的) closed connection” | 请求uri的时候出现的异常,是由于upstream还未返回应答给用户时用户断掉连接造成的,对系统没有影响,可以忽略 | 
| “recv() failed (104: Connection reset by peer)” | (1)服务器的并发连接数超过了其承载量,服务器会将其中一些连接Down掉; (2)客户关掉了浏览器,而服务器还在给客户端发送数据; (3)浏览器端按了Stop | 
| “(111: Connection refused) while connecting to upstream” | 用户在连接时,若遇到后端upstream挂掉或者不通,会收到该错误 | 
| “(111: Connection refused) while reading response header from upstream” | 用户在连接成功后读取数据时,若遇到后端upstream挂掉或者不通,会收到该错误 | 
| “(111: Connection refused) while sending request to upstream” | Nginx和upstream连接成功后发送数据时,若遇到后端upstream挂掉或者不通,会收到该错误 | 
| “(110: Connection timed out) while connecting to upstream” | nginx连接后面的upstream时超时 | 
| “(110: Connection timed out) while reading upstream” | nginx读取来自upstream的响应时超时 | 
| “(110: Connection timed out) while reading response header from upstream” | nginx读取来自upstream的响应头时超时 | 
| “(110: Connection timed out) while reading upstream” | nginx读取来自upstream的响应时超时 | 
| “(104: Connection reset by peer) while connecting to upstream” | upstream发送了RST,将连接重置 | 
| “upstream sent invalid header while reading response header from upstream” | upstream发送的响应头无效 | 
| “upstream sent no valid HTTP/1.0 header while reading response header from upstream” | upstream发送的响应头无效 | 
| “client intended to send too large body” | 用于设置允许接受的客户端请求内容的最大值,默认值是1M,client发送的body超过了设置值 | 
| “reopening logs” | 用户发送kill -USR1命令 | 
| “gracefully shutting down”, | 用户发送kill -WINCH命令 | 
| “no servers are inside upstream” | upstream下未配置server | 
| “no live upstreams while connecting to upstream” | upstream下的server全都挂了 | 
| “SSL_do_handshake() failed” | SSL握手失败 | 
| “SSL_write() failed (SSL:) while sending to client” | |
| “(13: Permission denied) while reading upstream” | |
| “(98: Address already in use) while connecting to upstream” | |
| “(99: Cannot assign requested address) while connecting to upstream” | |
| “ngx_slab_alloc() failed: no memory in SSL session shared cache” | ssl_session_cache大小不够等原因造成 | 
| “could not add new SSL session to the session cache while SSL handshaking” | ssl_session_cache大小不够等原因造成 | 
| “send() failed (111: Connection refused)” | 
nginx访问日志,错误日志参数说明的更多相关文章
- nginx配置文件详解----第一篇【访问与错误日志】
		error_log错误日志 access_log访问日志 log_format指令 语法: log_format name string …;默认值: log_format combined “ ... 
- Nginx 错误日志配置
		1.Nginx错误日志信息介绍: error_log的语法格式及参数说明: error_log file level; 关键字 日志文件 错误日志级别 其中,关键字 ... 
- nginx错误日志级别
		在配置nginx.conf 的时候,有一项是指定错误日志的,默认情况下你不指定也没有关系,因为nginx很少有错误日志记录的.但有时出现问题时,是有必要记录一下错误日志的,方便我们排查问题.error ... 
- Nginx错误日志(error_log)配置及信息详解
		Nginx错误日志信息介绍 Nginx的错误信息是调试Nginx服务的重要手段,属于核心功能模块(ngx_core_module)的参数,该参数的名字为error_log,可以放在Main区块中全局配 ... 
- MySQL 错误日志(Error Log)
		同大多数关系型数据库一样,日志文件是MySQL数据库的重要组成部分.MySQL有几种不同的日志文件.通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等. 这些日志能够帮助我们定位mysqld ... 
- Mysql中错误日志、binlog日志、查询日志、慢查询日志简单介绍
		前言 数据库的日志是帮助数据库管理员,追踪分析数据库以前发生的各种事件的有力根据.mysql中提供了错误日志.binlog日志(二进制日志).查处日志.慢查询日志.在此,我力求解决下面问题:各个日志的 ... 
- Logstash收集nginx访问日志和错误日志
		1.收集访问日志 1).首先是要在nginx里面配置日志格式化输出 log_format main "$http_x_forwarded_for | $time_local | $reque ... 
- Linux(7)- Nginx.conf主配置文件、Nginx虚拟主机/访问日志/限制访问IP/错误页面优化、Nginx反向代理、Nginx负载均衡
		一.Nginx.conf主配置文件 Nginx主配置文件conf/nginx.conf是一个纯文本类型的文件,整个配置文件是以区块的形式组织的.一般,每个区块以一对大括号{}来表示开始与结束. 核心模 ... 
- nginx配置之错误和访问日志功能
		错误日志功能:logs/error.log nginx.conf中: #error_log logs/error.log; #error_log logs/error.log notice; #err ... 
随机推荐
- android中XRecyclerView控件的使用
			控件的地址:https://github.com/XRecyclerView/XRecyclerView XRecyclerView控件是一个加强版的RecyclerView,可以很方便的实现下拉刷新 ... 
- docker安装tomcat
			先在官网上找可用的镜像 我使用的是7-jre8 获取tomcat镜像的命令:$docker pull tomcat:7-jre8 获取完镜像以后,通过命令可以列举出已有的镜像: 列举镜像的命令:$do ... 
- C#--串行化与反串行化
			串行化是指存储和获取磁盘文件.内存或其他地方中的对象.在串行化时,所有的实例数据都保存到存储介质上,在取消串行化时,对象会被还原,且不能与其原实例区别开来.只需给类添加Serializable属性,就 ... 
- 树莓派3中运行Netcore2.0程序
			一.简介 Netcore2.0发部后,可以运行在Arm平台上.因此,我们可以尝试在装了Debain的树莓派中运行. 二.方法: 1.在自己的电脑上使用VS写一个NetCore2.0的控制台程序,我假设 ... 
- cmder切换路径、设置命令别名
			alias alias hub= cd /d d:github/ cd $ help cd 显示当前目录名或改变当前目录. CHDIR [/D] [drive:][path] CHDIR [..] C ... 
- 算法笔记_232:提取拼音首字母(Java)
			目录 1 问题描述 2 解决方案 1 问题描述 在很多软件中,输入拼音的首写字母就可以快速定位到某个词条.比如,在铁路售票软件中,输入: “bj”就可以定位到“北京”.怎样在自己的软件中实现这个功 ... 
- LIST OF NOSQL DATABASES [currently 150]
			http://nosql-database.org Core NoSQL Systems: [Mostly originated out of a Web 2.0 need] Wide Column ... 
- ES6 Generator async
			Generator 函数是 ES6 提供的一种异步编程解决方案 async 函数使得异步操作变得更加方便,是 Generator 函数的语法糖. js单线程的原因是:避免DOM渲染冲突! 更新:201 ... 
- python之tcp自动重连
			操作系统: CentOS 6.9_x64 python语言版本: 2.7.13 问题描述 现有一个tcp客户端程序,需定期从服务器取数据,但由于种种原因(网络不稳定等)需要自动重连. 测试服务器示例代 ... 
- Python定向爬虫实战
			转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/7019963.html 一:requests模块介绍 requests是第三方http库,可以十分方便地实现py ... 
