zoukankan      html  css  js  c++  java
  • Apache、Nginx、IIS日志记录分析&详解

    Apache、Nginx、IIS日志记录分析

    一、Apache

    1.1.Windows Server 2008 R2平台

    1.1.1.日志位置及配置

    (1)启动Apache后,Apache会自动生成两个日志文件,这两个日志文件分别是访问日志access.log和错误日志error.log。

    (2)我们可以在Apache配置文件httpd.conf中,配置Apache访问日志格式。

    #下面两句定义不同模式下的日志记录格式
    LogFormat "%h %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined
    LogFormat "%h %l %u %t "%r" %>s %b" common
    #下面一句定义日志文件存储位置以及采用的记录格式
    CustomLog "logs/access.log" common
    

    解释:

    apache中日志记录格式主要有两种,普通型(common)和复合型(combined),安装时默认使用普通型(common)类型日志记录访问信息。

    1.1.2.分析

    (1)以下是一段标准的采用common记录格式下的日志记录

    192.168.2.184 - - [20/Apr/2020:17:17:18 +0800] "GET /pikachu-master HTTP/1.1" 301 247
    

    分析如下:

    字段值 字段名称 含义
    192.168.2.184 客户端IP 访问服务端的IP
    -
    - 登录名 客户端访问服务验证时提供的名字(匿名的情况下为-)
    [20/Apr/2020:17:17:18 +0800] 时间 客户段请求的时间(“+0800”表示服务器所处时区位于UTC之后的8小时)
    "GET /pikachu-master HTTP/1.1" 方法+资源+协议 客户端请求方式、请求的资源文件、客户端采用的协议
    301 状态代码 301代表所请求的页面已经转移至新的 URL
    247 字节数 服务端发送给客户端的字节长度

    (2)以下是一段标准的采用combined记录格式下的日志记录

    192.168.2.184 - - [20/Apr/2020:17:36:18 +0800] "GET /pikachu-master/ HTTP/1.1" 200 35392 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:75.0) Gecko/20100101 Firefox/75.0"
    

    分析如下:

    字段值 字段名称 含义
    ... ... ...
    "-" 引用站点 用户访问的前一个站点。此站点提供到当前站点的链接。
    "Mozilla/5.0
    (Windows NT 10.0; Win64; x64; rv:75.0)
    Gecko/20100101 Firefox/75.0"
    客户端浏览器提供的浏览器识别信息 浏览器内核版本、操作系统版本、浏览器版本

    1.2.CentOS 7 平台

    1.2.1.日志位置

    cat /var/log/httpd/access_log 查看Apache日志
    

    1.2.2.分析

    以下是一段记录

    192.168.2.184 - - [11/Apr/2020:21:51:47 +0800] "GET /favicon.ico HTTP/1.1" 404 209 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:75.0) Gecko/20100101 Firefox/75.0"
    

    通过观察和Windows下的一摸一样,故分析可以参照1.1.2

    二、Nginx

    2.1.Windows Server 2008 R2平台

    2.1.1.日志位置

    我们可以在配置文件中查看或者更改日志的存放位置

    2.1.2.分析

    以下是一段日志。

    192.168.33.254 - - [20/Feb/2020:22:57:27 +0800] "POST /pikachu-master/vul/burteforce/bf_form.php HTTP/1.1" 200 4899 "http://192.168.33.254/pikachu-master/vul/burteforce/bf_form.php" "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:72.0) Gecko/20100101 Firefox/72.0"
    

    详情请看2.2(与Linux下的一样)

    2.2.CentOS 7 平台

    2.2.1.日志位置及配置

    #日志位置
    /var/log/nginx/access.log
    
    #nginx配置文件位置
    vim /etc/nginx/nginx.conf(可能有所不一样)
    
    #配置文件中关于日志的字段(日志格式+日志存放位置)
    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  /var/log/nginx/access.log  main;
    

    2.2.2.分析

    以下是一段Nginx日志:

    192.168.2.184 - - [20/Apr/2020:17:59:09 +0800] "GET /index.html HTTP/1.1" 200 612 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:75.0) Gecko/20100101 Firefox/75.0" "-"
    

    分析:

    字段值 字段名称 含义
    192.168.2.184 $remote_addr 客户端(用户)的IP地址
    - - - $remote_user 客户端的用户名,匿名访问为-
    [20/Apr/2020:17:59:09 +0800] [$time_local] 访问时间
    "GET /index.html HTTP/1.1" "$request" 请求方式以及请求的资源URI地址
    200 $status 状态码(200 OK)
    612 $body_bytes_sent 请求的页面大小
    "-" "$http_referer" 来源页面,即从哪个页面转到本页
    "Mozilla/5.0
    (Windows NT 10.0; Win64; x64; rv:75.0)
    Gecko/20100101 Firefox/75.0"
    "$http_user_agent" 浏览器信息,操作系统信息
    "-" "$http_x_forwarded_for" 获取到真实IP,获取不到则显示为 -

    3.2.3.自定义日志记录字段

    如果我们想要获取的信息并没有记录下来,例如:服务器的处理时间等等。那么我们可以在配置文件中添加以下内容,从而获取到我们想要的信息。

    $request_time
    #记录请求处理时间(以秒为单位,携带毫秒的解决方案),从读取客户端第一个字节开始算起,到发送最后一个字节给客户端的时间间隔
    
    $upstream_response_time
    #记录nginx从后端服务器(upstream server)获取响应的时间(以秒为单位,携带毫秒的解决方案),多个请求的时间以逗号分隔
    
    $request_length
    #记录请求长度(包括请求行,请求头,请求体)
    
    $bytes_sent
    #发送给客户端的字节数,不同于$body_bytes_sent(发送给客户端的响应体字节数)
    

    三、IIS

    3.1.IIS 7日志记录所在位置(Windows Server 2008 R2)

    除此之外,我们可以通过Internet信息服务(IIS)管理器设置日志中要记录的字段:

    3.2.分析

    一段完整的日志记录如下:

    #Software: Microsoft Internet Information Services 7.5
    #Version: 1.0
    #Date: 2020-04-20 07:28:44
    #Fields: date time s-sitename s-computername s-ip cs-method cs-uri-stem cs-uri-query s-port cs-username c-ip cs-version cs(User-Agent) cs(Cookie) cs(Referer) cs-host sc-status sc-substatus sc-win32-status sc-bytes cs-bytes time-taken
    
    2020-04-20 07:28:44 W3SVC4 FENGWENBO 192.168.2.254 GET /picnews.asp - 8004 - 192.168.2.184 HTTP/1.1 Mozilla/5.0+(Windows+NT+10.0;+Win64;+x64;+rv:75.0)+Gecko/20100101+Firefox/75.0 zh_choose=n;+ASPSESSIONIDAQSBBTTA=FHLLDFKCKALEMJAPACIFLDLL http://192.168.2.254:8004/ 192.168.2.254:8004 200 0 0 731 500 327
    

    各字段含义如下:

    字段值 字段名称 含义
    2020-04-20 日期(date) 活动发生的日期
    07:28:44(+8) 时间(time) 活动发生的时间
    W3SVC4 服务名(s-sitename) 客户端所访问的该站点的 Internet 服务和实例的号码
    FENGWENBO 服务器名(s-computername) 生成日志项的服务器名称。
    192.168.2.254 服务器IP(s-ip) 生成日志项的服务器IP地址
    GET 方法(cs-method) 客户端执行的操作
    /picnews.asp 请求访问的页面(cs-uri-stem) 客户端访问的文件
    访问的查询字符串(cs-uri-query) 客户端正在尝试执行的查询(此时没有,显示为-)
    8004 服务器端口(s-port) 客户端连接服务端的端口
    - 客户端用户名(cs-username) 匿名用户登陆,显示为-
    192.168.2.184 客户端IP(c-ip) 真实的访问服务器的客户端IP地址
    HTTP/1.1 协议版本(cs-version) 客户端使用的协议
    Mozilla/5.0
    +(Windows+NT+10.0;
    +Win64;+x64;+rv:75.0)
    +Gecko/20100101
    +Firefox/75.0
    用户代理(cs(User-Agent)) 在客户端使用的浏览器
    zh_choose=n;
    +ASPSESSION
    IDAQSBBTTA
    =FHLLDFKCK
    ALEMJAPACIFLDLL
    cookie(cs(Cookie)) 发送或接收的 Cookie 的内容
    http://192.168.2.254:8004/ 引用站点(cs(Referer)) 用户访问的前一个站点。此站点提供到当前站点的链接。
    192.168.2.254:8004 主机(cs-host) 显示主机头的内容
    200 协议返回状态(sc-status) 以HTTP或FTP表示的操作的状态(200 OK)
    0 HTTP子协议的状态(sc-substatus)
    0 Win32® 状态(sc-win32-status) 用 Windows® 使用的术语表示的操作的状态
    731 服务器发送的字节数(sc-bytes) 服务器发送的字节数。
    500 服务器接受的字节数(cs-bytes) 服务器接收的字节数。
    327 所用时间(time-taken) 操作花费的时间长短(亳秒)
  • 相关阅读:
    python-装饰器
    Django-session相关操作+redis
    Could not connect to Redis at 127.0.0.1:6379: 由于目标计算机积极拒绝,无法连接。redis启动失败
    mybatis高级特性
    Elasticsearch从入门到熟练使用
    sharding-jdbc从入门到熟练使用
    mysql主从复制搭建(普通安装和docker方式)
    领域驱动设计入门及简单落地
    docker的一些基本命令
    docker发布jar包项目
  • 原文地址:https://www.cnblogs.com/Feng-L/p/12739721.html
Copyright © 2011-2022 走看看