Nginx日志管理——了解Nginx日志选项配置以及自定义日志格式使用分析

访客 阅读:218 2021-09-05 17:52:44 评论:0
本文章主要介绍了Nginx日志管理——了解Nginx日志选项配置以及自定义日志格式使用,具有不错的的参考价值,希望对您有所帮助,如解说有误或未考虑完全的地方,请您留言指出,谢谢!

一、引言

不管什么程序,一般都会有日志的。哪怕你在浏览器上网访问了一个网站,也会有记录保存的。在这个里互联网时代,想在网上不留下痕迹那是很难的。在我们开发一个程序,日志功能往往也是不可缺少的,今天我们就来讲讲这个Nginx的日志是怎么样来玩的。

二、了解日志管理

我们查看nginx安装目录下有个logs,包含了三个文件 "access.log 、error.log、nginx.pid"。

当然,日志配置肯定也是通过nginx.conf配置文件来进行配置的 ,那我先来看配置文件是怎么写的。

"access_log  logs/access.log  main" 这个是指access.log日志用main格式来显示。

main格式是什么?mian格式是我们已经定义好了的一种各种,并取个名字便于引用。

默认的main格式中具体用了哪些选项来记录日志呢? 我给大家一一的列举出来

 $remote_addr - $remote_user 访问的ip地址 - 访问的用户
$time_local 请求的时间
$request 请求的方式,如:get、post等
$status $body_bytes_sent  请求体、body的长度
$http_referer referer 来源信息,可以查看是用什么浏览器请求的
$http_user_agent、$http_x_forwarded_for 用户代理/蜘蛛、被转发请求的原始ip
 
//该文件是存放到nginx安装目录下conf文件夹中 
  
//全局区 
  
//代表着当前有一个工作的子进程,可以自行修改,但是太多了无益因为会争夺cpu资源。一般最多设置成cpu数*核数 
worker_processes  1; 
  
//一般配置nginx的连接特性 
events { 
    //这里是指一个子进程最大允许连接1024个连接 
    worker_connections  1024; 
} 
  
//这里是配置http服务器的主要段 
http { 
     
    include       mime.types; 
    default_type  application/octet-stream; 
    sendfile        on; 
    keepalive_timeout  65; 
 
 
    //这里配置的是日志的显示格式 
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" ' 
    #                 '$status $body_bytes_sent "$http_referer" ' 
    #                 '"$http_user_agent" "$http_x_forwarded_for"'; 
     
    //这里调用指定日志显示的格式 
    #access_log  logs/access.log  main; 
 
  
    //这里是配置虚拟主机段 
    server { 
        listen       80;//监听的端口 
        server_name  localhost;//监听访问地址 
  
        #charset koi8-r; 
  
        #access_log  logs/host.access.log  main; 
  
        //定位,把特殊的文件或者路径再次定位 
        location / { 
            root   html;//定位的目录,默认是ngxin安装目录下的html文件夹中 
            index  index.html index.htm;//定位的具体文件 
        } 
    } 

三、自定义日志格式

接下来我们就试试自己自定义一个日志显示的格式吧,只需要记录访问的ip和访问时间即可。

1、先定义日志格式:"log_format  mylog 'ip:$remote_addr - $time_local';"

2、调用显示的格式: "access_log logs/access.log mylog;"

3、保存配置文件,记得重新加载一下配置文件。

4、然后在浏览器访问,再去看看access.log保存的日志是什么格式的。


标签:java
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

发表评论
搜索
KIKK导航

KIKK导航

排行榜
关注我们

一个IT知识分享的公众号