12.10 Nginx访问日志 12.11 Nginx日志切割 ​ 12.12 静态文件不记录日志和过期时间...

##12.10 Nginx访问日志

日志格式 vim /usr/local/nginx/conf/nginx.conf //搜索log_format

输入图片说明

combined_realip 为 日志定义的名字, 可自己更改, 如 aming_log

输入图片说明

除了在主配置文件nginx.conf里定义日志格式外,还需要在虚拟主机配置文件中增加

access_log /tmp/1.log combined_realip;

这里的combined_realip就是在nginx.conf中定义的日志格式名字, 如果不写会使用默认的日志格式(比较简单)

-t && -s reload curl -x127.0.0.1:80 test.com -I cat /tmp/1.log

12.11 Nginx日志切割

自定义shell 脚本

vim /usr/local/sbin/nginx_log_rotate.sh//写入如下内容

#! /bin/bash
## 假设nginx的日志存放路径为/data/logs/
d=`date -d "-1 day" +%Y%m%d`
logdir="/data/logs"
nginx_pid="/usr/local/nginx/logs/nginx.pid"      //pid位置要正确
cd $logdir
for log in `ls *.log`
do
    mv $log $log-$d
done

/bin/kill -HUP `cat $nginx_pid`    //等效于 /usr/local/nginx/sbin/nginx -s reload

sh -x /usr/local/sbin/nginx_log_rotate.sh   // x选项可看到脚本执行过程

别忘记定期删除

任务计划 0 0 * * * /bin/bash /usr/local/sbin/nginx_log_rotate.sh

[ -f /usr/local/nginx/logs/nginx.pid ] && kill -USR1 cat /var/run/nginx.pid

1.[ -f ] 解释 [ 是 linux 命令, 不信, which [ 试试;跟 test 命令 含义 一样 ; [ -f xxx] 是 测试 文件 是否 存在

  1. 系统将 进程xx 的 进程号 存储 在 /usr/local/nginx/logs/nginx.pid 文件下 ;所以 cat/usr/local/nginx/logs/nginx.pid 是为了 取到 nginx 的进程号

3.kill -USR1

USR1亦通常被用来告知应用程序重载配置文件;例如,向Apache HTTP服务器发送一个USR1信号将导致以下步骤的发生:停止接受新的连接,等待当前连接停止,重新载入配置文件,重新打开日志文件,重启服务器,从而实现相对平滑的不关机的更改。

另外一种方法: 使用系统logrotate命令切割日志的方法

12.12 静态文件不记录日志和过期时间

配置如下 红色的\代表脱意 | 表示或者 expires 过期时间

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico)$
{
          expires      7d;
          access_log off;
}

location ~ .*\.(js|css)$
 {
          expires      12h;
          access_log off;
 }

-t && -s reload
curl -x127.0.0.1:80 -I  www.test.com/images/123.png
tail -f /tmp/1.log

转载于:https://my.oschina.net/u/3746773/blog/1634238

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值