从零开始的Nginx [ 6 ] --- Nginx的日志配置,log_format 、error_log指令,日志轮转,错误页面配置
文章目录
nginx 错误页面配置
一、Rewrite 相关指令
1. last,break详解
[[email protected] html]# cat /etc/nginx/conf.d/nginx.conf
server {
listen 80;
server_name localhost;
access_log /var/log/nginx/http_access.log main;
error_log /var/log/nginx/last-break.log debug;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
location /break/ {
root /usr/share/nginx/html;
rewrite .* /test/break.html break;
}
location /last/ {
root /usr/share/nginx/html;
rewrite .* /test/last.html last;
}
location /test/ {
root /usr/share/nginx/html;
rewrite .* /test/test.html break;
}
}
[[email protected] conf.d]# cd /usr/share/nginx/html/
[[email protected] html]# mkdir test
[[email protected] html]# echo "last" > test/last.html
[[email protected] html]# echo "break" > test/break.html
[[email protected] html]# echo "test" > test/test.html
测试
[[email protected] html]# curl 127.0.0.1/break/break.html
break
[[email protected] html]# curl 127.0.0.1/test/test.html
test
[[email protected] html]# curl 127.0.0.1/last/last.html
test
当 使用 /last/last.html 访问的时候,会匹配到 /last/
匹配到后,请求的 url 会被重写为 /test/last.html
并且这里的 rewrite .* /test/last.html last;
后面的 flag 是 last ,因此就会使用重写过的 URL /test/last.html
重新进入 server{}
中进行匹配
注意:
- last 标记在本条 rewrite 规则执行完后,会对其所在的 server { … } 标签重新发起请求;
- break 标记则在本条规则匹配完成后,停止匹配,不再做后续的匹配;
- 使用 alias 指令时,必须使用 last;
- 使用 proxy_pass 指令时,则必须使用break。
二、Nginx 日志配置
1 nginx 日志介绍
nginx
有一个非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志, 所需日志模块 ngx_http_log_module
的支持,日志格式通过 log_format
命令来定义,日志对于统计和排错是非常有利的,下面总结了 nginx
日志相关的配置 包括 access_log
、log_format
、rewrite_log
、error_log
。
设置访问日志
access_log path [format [buffer=size] [gzip[=level]] [flush=time];
关闭访问日志
access_log off;
- path 指定日志的存放位置。
-
format 指定日志的格式。默认使用预定义的
combined
。 - buffer 用来指定日志写入时的缓存大小。默认是64k。
- gzip 日志写入前先进行压缩。压缩率可以指定,从1到9数值越大压缩比越高,同时压缩的速度也越慢。默认是1。
-
flush 设置缓存的有效时间。如果超过flush指定的时间,缓存中的内容将被清空。
2 log_format 指令
Nginx 预定义了名为combined
日志格式,如果没有明确指定日志格式默认使用该格式:
log_format combined '$remote_addr - r e m o t e u s e r [ remote_user [ remoteuser[time_local] ’
‘"$request" $status KaTeX parse error: Double superscript at position 37: … '̲"http_referer" “$http_user_agent”’;
如果不想使用Nginx预定义的格式,可以通过log_format
指令来自定义。
语法
log_format name [escape=default|json] string ...;
- name 格式名称。在 access_log 指令中引用。
-
escape 设置日志书写内存方式是
json
还是default
,默认是default
。 - string 要定义的日志格式内容。该参数可以有多个。参数中可以使用Nginx变量。
log_format
指令中常用的一些变量:
$remote_addr, $http_x_forwarded_for #记录客户端IP地址
$remote_user #记录客户端用户名称
$request #记录请求的URL和HTTP协议
$status #记录请求状态
$body_bytes_sent #发送给客户端的字节数,不包括响应头的大小
$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 #通用日志格式下的本地时间。
实验
通过日志查看访问服务器的ip
代理机配置中加入
proxy_set_header X-Real-IP $remote_addr;
访问 服务器
[[email protected] ~]# curl 服务器ip
bilibili 干杯!!!
去服务器中查看日志信息
[[email protected] ~]# cat /var/log/nginx/last-break.log
2020/12/18 02:02:17 [info] 29870#29870: *1 client 192.168.116.157 closed keepalive connection
2 error_log 指令
错误日志在Nginx中是通过error_log
指令实现的。该指令记录服务器和请求处理过程中的错误信息。
语法
配置错误日志文件的路径和日志级别。
error_log file [level];
Default:
error_log logs/error.log error;file
参数指定日志的写入位置。level
参数指定日志的级别。level可以是debug
,info
,notice
,warn
,error
,crit
,alert
,emerg
中的任意值。可以看到其取值范围是按紧急程度从低到高排列的。只有日志的错误级别等于或高于level指定的值才会写入错误日志中。默认值是error
。
扩展日志级别:
debug级别:低级别,包含的信息非常详细
info级别:稍微的高一点了。用的多一些。
notice 和warning
notice:相当于提示
warning:警告 和warn 一样
err和error 一样。
crit:比较严重了
alert:告警,很严重
emerg: 恐慌级别, 级别最高的
基本用法
error_log /var/logs/nginx/nginx-error.log
配置段:http
,server
,location
作用域。
例子中指定了错误日志的路径为:/var/logs/nginx/nginx-error.log
,日志级别使用默认的error
。
3 rewrite_log 指令
由ngx_http_rewrite_module
模块提供的。用来记录重写日志的。对于调试重写规则建议开启,启用时将在error log
中记录notice
级别的重写日志。
基本语法:
rewrite_log on | off;
默认值:
rewrite_log off;
配置段: http
, server
, location
, if
作用域。
4 nginx 日志配置总结
Nginx中通过access_log
和error_log
指令配置访问日志和错误日志,通过log_format
我们可以自定义日志格式。
详细的日志配置信息可以参考Nginx官方文档
5 单独开启server的访问日志
需要:代理机与server端已经可以代理访问
首先修改代理机的配置
[[email protected] nginx]# cat /etc/nginx/nginx.conf
#user nobody;
worker_processes 1;
events {
worker_connections 1024;
}
http{
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://server机IP;
proxy_set_header X-REAl-IP $remote_addr;
}
}
}
server机
[email protected] ~]# cat /etc/nginx/nginx.conf
user nginx;
worker_processes 1;
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_real_ip"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
[[email protected] conf.d]# nginx -s reload
[[email protected] ~]# > /var/log/nginx/http_access.log
代理机访问(或其他机访问代理机)
[[email protected] nginx]# curl 127.0.0.1
bilibili 干杯!!!
回server机查看日志
[[email protected] ~]# cat /var/log/nginx/http_access.log
192.168.116.157 - - [18/Dec/2020:08:12:18 -0500] "GET / HTTP/1.0" 200 25 "-" "curl/7.29.0" "127.0.0.1"
#最前面是代理机,最后面是访问的端口ip 是多少
6 nginx的日志轮转
[[email protected] ~]# rpm -ql nginx |grep log
/etc/logrotate.d/nginx
/var/log/nginx
[[email protected] ~]# vim /etc/logrotate.d/nginx
/var/log/nginx/*.log { #指定需要轮转处理的日志文件
daily #日志文件轮转周期,可用值为: daily/weekly/yearly
missingok # 忽略错误信息
rotate 7 # 轮转次数,即最多存储7个归档日志,会删除最久的归档日志
minsize 5M #限制条件,大于5M的日志文件才进行分割,否则不操作
dateext # 以当前日期作为命名格式
compress # 轮循结束后,已归档日志使用gzip进行压缩
delaycompress # 与compress共用,最近的一次归档不要压缩
notifempty # 日志文件为空,轮循不会继续执行
create 640 nginx nginx #新日志文件的权限
sharedscripts #有多个日志需要轮询时,只执行一次脚本
postrotate # 将日志文件转储后执行的命令。以endscript结尾,命令需要单独成行
if [ -f /var/run/nginx.pid ]; then #判断nginx的PID。# 默认logrotate会以root身份运行
kill -USR1 `cat /var/run/nginx.pid`
fi
endscript
}
执行命令:
[[email protected] nginx]# /usr/sbin/logrotate -f /etc/logrotate.conf
创建计划任务:
[[email protected] nginx]# crontab -e
59 23 * * * /usr/sbin/logrotate -f /etc/logrotate.conf
查看压缩的日志
[[email protected] bin]# ls /var/log/nginx/
access.log http_access.log last-break.log
error.log http_access.log-20201218 last-break.log-20201218
7 nginx 错误页面配置
nginx错误页面包括404 403 500 502 503 504等页面,只需要在server中增加以下配置即可:/etc/nginx/conf.d/nginx.conf
error_page 404 /404.html;
location = /404.html {
root /usr/share/nginx/html;
}
注意:/usr/share/nginx/html
路径下必须有404.html
这个文件!!!
404.html上如果引用其他文件的png或css就会有问题,显示不出来,因为其他文件的访问也要做配置;
为了简单,可以将css嵌入文件中,图片用base编码嵌入;
编译文件 404.html
文件,并写入如下内容:
[[email protected] bin]# cat /usr/share/nginx/html/404.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
<title>404</title>
<style>
.layout-table{display:table;height:100%;width:100%;vertical-align: middle;margin-top:150px}
.layout-table-cell{display: table-cell;vertical-align: middle;text-align:center}
.layout-tip{font-size:28px;color:#373737;margin: 0 auto;margin-top:16px;border-bottom: 1px solid #eee;padding-bottom: 20px;width: 360px;}
#tips{font-size:18px;color:#666666;margin-top:16px;}
</style>
</head>
<body class="layui-layout-body">
<div class="layui-layout layui-layout-admin">
<div class="layui-body">
<div class="layout-table">
<div class="layout-table-cell">
<img src="//static.hdslb.com/error/very_sorry.png" class="layout-img">
<p class="layout-tip">哎呀,页面被22娘偷走啦!</p>
<p id="tips">请检查您的网络连接是否正常或者输入的网址是否正确</p>
</div>
</div>
</div>
</div>
</body>
</html>
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5IDRJA0X-1608347670999)(C:\Users\admin\Pictures\其他图\image-20201219110106824.png)]