Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1352248
  • 博文数量: 145
  • 博客积分: 1440
  • 博客等级: 少尉
  • 技术积分: 2986
  • 用 户 组: 普通用户
  • 注册时间: 2012-07-24 23:47
个人简介

我一直在走,至少还有条路,也好于无路可走…

文章分类

全部博文(145)

文章存档

2023年(1)

2017年(2)

2016年(5)

2015年(13)

2014年(13)

2013年(70)

2012年(41)

分类: LINUX

2013-03-04 14:02:21

                                                                 Nginx日志管理
1.log_format指令用来设置日志的记录格式,语法如下:
    log_format name format (format ....)
  具体日志格式如下:
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                       '$status $body_bytes_sent "$http_referer" '
                        '"$http_user_agent" "$http_x_forwarded_for"';
                        $http_x_forwarded_for 和 $remote_user用于记录ip地址
                        $remote_user         用来记录远程客户端用户名称
                        $time_local          用来记录访问时间及地区
                        $request             用于记录请求的URL与HTTP协议
                        $status              用于记录请求的状态,例如状态为200,页面找不到时为404
                        $body_bytes_sent     用于记录发送给客户端的文件主体内容大小
                        $http_referer        用于记录是从哪个页面链接访问过来的
                        $http_user_agent     用于记录客户端浏览器的相关信息
                        
                                                           开启日志打开缓存
2.为了提高包含变量的日志文件存放路径的性能,可以使用:
                        open_log_file_cache指令来设置,格式如下:

                         open_log_file_cache max=N [inactive=time][min_use=N][valid=time] |off 该指令默认是禁止的,等同于: open_log_file_cache off;
                         max        :设置缓存中的最大文件描述数量
                         inactive:  设置一个时间,如果在设置的时间内没有使用此文件描述,则自动删除此描述
                         min_uses:   在参数inactive指定的时间范围内,如果日志文件超过使用次数,则该日志文件的描述计入缓存,默认为10秒钟
                         valid   :设置多长时间检查一次,看日志文件路径与文件名是否仍然存在,默认60秒。
例子:       open_log_file_cache max=1000 inactive=20s min_uses=2 valid=1m                                 

                                                          Nginx 日志分割
    #vim logs.sh
    #!/bin/bash
    #Nginx日志存放位置
    logs_path="/usr/local/nginx/logs"
    #将日志改名
    mkdir -p $(logs_path)$(date -d "yesterday" +"%Y")/$(date -d "yesterday" + "%m")/
     mv $(logs_path)access.log $(logs_path)$(date -d "yesterday" +"%Y" )/$(date -d "yesterday" + "%m" )/access_$(date -d "yesterday" + "%Y%m%d").log
    #重启Nginx服务
     service nginx reload
    #创建计划任务
    #crontab -l
    01 01 * * * /bin/bash/logs.sh

阅读(4598) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~