当前位置:  操作系统/服务器>linux
本页文章导读:
    ▪nginx 日志分析的实例学习      本节内容: Nginx 日志分析 分析网站日志:   代码示例: log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '                       '$status $body_bytes_sent "$http_referer" '      .........
    ▪nginx location配置规则分享      本节内容: Nginx location匹配规则 nginx 正则表达式匹配,其中:   * ~ 为区分大小写匹配 * ~* 为不区分大小写匹配 * !~和!~*分别为区分大小写不匹配及不区分大小写不匹配 文件及目录匹配,.........
    ▪nginx根据$remote_addr分发 nginx根据客户端IP分发      本节内容: Nginx根据客户端IP分发 nginx根据remote_addr分发location匹配规则:   代码示例: server {         listen       80;         server_name  www.;         location ~ ^(.*)\/\.svn\/{     .........

[1]nginx 日志分析的实例学习
    来源: 互联网  发布时间: 2013-12-24

本节内容:
Nginx 日志分析

分析网站日志:
 

代码示例:
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"'
                      '"$upstream_response_time"  "$request_time"';

附,字段 含义 范例
 

代码示例:
remote_addr:   客户机的IP地址 (IP头)     10.60.56.245
remote_user    记录客户端用户名称
time_local:     访问日期 时间和时差       [06/Nov/2013:14:50:49 +0800]
request:       用户请求url(/blog_article/方式 资源 协议/index.html) "GET /api/general_search?mode=package&page=0  HTTP/1.1"
status:        请求状态  
200
body_bytes_sent:传送的字节数(不包含HTTP头信息) 238871
http_referer:  请求的URL路径(从哪个页面链接访问过来的)http://www./api/general_search
http_user_agent:客户端浏览器提供的浏览器识别信息 "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0; NP06)"
upstream_response_time: 反向代理耗时 "0.035"
request_time: 请求时间"0.035"

抽取日志中一条日志:
 

10.60.56.246 - - [06/Nov/2013:15:01:14 +0800] "GET /api/general_search?mode=package&page=0&page_size=10&query=&search=itemName%3D%E8%BD%A7%E7%A1%AC%E5%8D%B7__sfCate%3DTL80__thick%3D-.18__sfWeight%3D4-__sfSS%3D2100__mymall%3D1__virtual%3D0__time%3D1383721277566&shop=&sort=discounted_price%20desc HTTP/1.1" 200 2394 "http://www./search/?itemName=\xE8\xBD\xA7\xE7\xA1\xAC\xE5\x8D\xB7&sfCate=TL80&mymall=1&time=1383721203554" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0; NP06)" "116.231.163.147, 10.60.56.243" "0.035"  "0.035"

分析命令:
 

代码示例:
cat access.log |awk -F ",," '{print $1,$3,$5,$6,$9,$10,$11}' |more

您可能感兴趣的文章:
Nginx日志模块分析详解
Nginx关闭日志的方法
Nginx日志分析 Nginx日志切割与Awstats配置
nginx日志配置、Nginx日志分割
有关nginx日志格式的设计分享
nginx日志统计访问时间的例子
nginx日志配置文件的格式说明
一个分割ngnix网站日志的Shell脚本
nginx日志报大量400错误的解决方法
nginx关闭favicon.ico日志记录的方法
nginx与apache日志格式的区别
nginx日志中记录cookie的实现方法
修改nginx访问日志的时间格式的方法
Nginx日志中过滤关键字的写法
nginx 日志分析实例


    
[2]nginx location配置规则分享
    来源: 互联网  发布时间: 2013-12-24

本节内容:
Nginx location匹配规则

nginx 正则表达式匹配,其中:
 

* ~ 为区分大小写匹配
* ~* 为不区分大小写匹配
* !~和!~*分别为区分大小写不匹配及不区分大小写不匹配
文件及目录匹配,其中:
* -f和!-f用来判断是否存在文件
* -d和!-d用来判断是否存在目录
* -e和!-e用来判断是否存在文件或目录
* -x和!-x用来判断文件是否可执行

flag标记:
 

* last 相当于Apache里的[L]标记,表示完成rewrite
* break 终止匹配, 不再匹配后面的规则
* redirect 返回302临时重定向 地址栏会显示跳转后的地址
* permanent 返回301永久重定向 地址栏会显示跳转后的地址

附,一些可用的全局变量有,可以用做条件判断(待补全)
 

$args
$content_length
$content_type
$document_root
$document_uri
$host
$http_user_agent
$http_cookie
$limit_rate
$request_body_file
$request_method
$remote_addr
$remote_port
$remote_user
$request_filename
$request_uri
$query_string
$scheme
$server_protocol
$server_addr
$server_name
$server_port
$uri

    
[3]nginx根据$remote_addr分发 nginx根据客户端IP分发
    来源: 互联网  发布时间: 2013-12-24

本节内容:
Nginx根据客户端IP分发

nginx根据remote_addr分发location匹配规则:
 

代码示例:

server {
        listen       80;
        server_name  www.;

        location ~ ^(.*)\/\.svn\/{
            deny all;
         }

        location /status {
            stub_status on;
            access_log off;
            allow 172.16.10.0/24;
        }

        location /  {

                proxy_set_header   Host                www.;
                proxy_set_header   X-Real-IP        $remote_addr;
                proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;

            if ($remote_addr ~ "202.160.46.150|151") #如果有多个IP “(152|153|155)”
                {
                        proxy_pass http://172.16.10.1:8000;
                        break;
                }

                proxy_pass      http://172.16.10.2:8000;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        }

附,nginx location匹配规则

location匹配命令
~ #波浪线表示执行一个正则匹配,区分大小写
~* #表示执行一个正则匹配,不区分大小写
^~ #^~表示普通字符匹配,如果该选项匹配,只匹配该选项,不匹配别的选项,一般用来匹配目录
= #进行普通字符精确匹配
@ #"@" 定义一个命名的 location,使用在内部定向时,例如 error_page, try_files

=前缀的指令严格匹配这个查询。如果找到,停止搜索。
所有剩下的常规字符串,最长的匹配。如果这个匹配使用^?前缀,搜索停止。
正则表达式,在配置文件中定义的顺序。
如果第3条规则产生匹配的话,结果被使用。否则,如同从第2条规则被使用。

location 匹配的优先级(与location在配置文件中的顺序无关)
= 精确匹配会第一个被处理。如果发现精确匹配,nginx停止搜索其他匹配。
普通字符匹配,正则表达式规则和长的块规则将被优先和查询匹配,也就是说如果该项匹配还需去看有没有正则表达式匹配和更长的匹配。
^~ 则只匹配该规则,nginx停止搜索其他匹配,否则nginx会继续处理其他location指令。
最后匹配理带有"~"和"~*"的指令,如果找到相应的匹配,则nginx停止搜索其他匹配;
当没有正则表达式或者没有正则表达式被匹配的情况下,那么匹配程度最高的逐字匹配指令会被使用。
 

代码示例:
location  = / {
  # 只匹配"/".
  [ configuration A ]
}
location  / {
  # 匹配任何请求,因为所有请求都是以"/"开始
  # 但是更长字符匹配或者正则表达式匹配会优先匹配
  [ configuration B ]
}
location ^~ /images/ {
  # 匹配任何以 /images/ 开始的请求,并停止匹配 其它location
  [ configuration C ]
}
location ~* \.(gif|jpg|jpeg)$ {
  # 匹配以 gif, jpg, or jpeg结尾的请求.
  # 但是所有 /images/ 目录的请求将由 [Configuration C]处理.  
  [ configuration D ]
}

    
最新技术文章:
▪linux系统中的列出敏感用户的脚本代码
▪a10 config backup for aXAPI
▪一键备份gitolite服务器的Shell脚本
▪nagios 分发文件实现代码
▪阿里云云服务器Linux系统更新yum源Shell脚本
▪一个监控LINUX目录和文件变化的Shell脚本分享
▪Linux下实现SSH免密码登录和实现秘钥的管理、...
▪Shell正则表达式之grep、sed、awk实操笔记
▪3个备份系统文件并邮件发送的Shell脚本分享
▪CentOS 6.3下给PHP添加mssql扩展模块教程
▪监控网站是否可以正常打开的Shell脚本分享
▪shell脚本编程之if语句学习笔记
▪shell脚本编程之循环语句学习笔记
▪shell脚本编程之case语句学习笔记
▪Shell脚本实现的阳历转农历代码分享
▪Shell脚本实现复制文件到多台服务器的代码分...
▪Shell脚本实现批量下载网络图片代码分享
▪Shell脚本实现检测文件是否被修改过代码分享
▪Shell脚本数组用法小结
▪Shell脚本批量重命名文件后缀的3种实现
▪C语言实现的ls命令源码分享
▪Linux下查找后门程序 CentOS 查后门程序的shell脚...
▪Shell 函数参数
▪linux shell 自定义函数方法(定义、返回值、变...
▪Shell实现判断进程是否存在并重新启动脚本分...
▪Shell脚本break和continue命令简明教程
▪Shell脚本函数定义和函数参数
▪让代码整洁、过程清晰的BASH Shell编程技巧
▪shell常用重定向实例讲解
▪awk中RS、ORS、FS、OFS的区别和联系小结
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3