nginx学习(三) 使用shell命令和linux定时任务完成nginx日志管理

1.日志参数介绍

参数说明示例
$remote_addr客户端地址(远程地址)211.28.65.253
$remote_user客户端用户名称(远程客户机名称)-
$time_local访问时间和时区18/Jul/2012:17:00:01 +0800
$request请求的URI和HTTP协议“GET /article-10000.html HTTP/1.1”
$http_host请求地址,即浏览器中你输入的地址(IP或域名)192.168.100.100
$statusHTTP请求状态200
$upstream_statusupstream状态200
$body_bytes_sent发送给客户端文件内容大小1524
$http_refererurl跳转来源https://www.baidu.com/
$http_user_agent用户终端浏览器等信息-有可能是蜘蛛"Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; SV1; GTB7.0; .NET4.0C;
$ssl_protocolSSL协议版本TLSv1
$ssl_cipher交换数据中的算法RC4-SHA
$upstream_addr后台upstream的地址,即真正提供服务的主机地址10.10.10.100:80
$request_time整个请求的总时间0.205
$upstream_response_time请求过程中,upstream响应时间0.002

2.编写shell脚本

  • 创建shell脚本目录和脚本 mkdir /data cd /data vim runlog.sh
  • 编写脚本
# /bin/bash
LOGPATH=/usr/local/nginx/logs/zcom.access.log //日志文件
BASEPATH=/data //日志切换目录

bak=$BASEPATH/$(date -d yesterday +%Y%m%d%H%M).zcom.access.log //切换后日志目录+名称
#echo $bak //查看值

mv $LOGPATH $bak //移动目录
touch $LOGPATH   //创建新文件

kill -USR1 `cat /usr/local/nginx/logs/nginx.pid` //更新nginx目录节点

3.编写定时任务

  • 打开定时任务 crontab -e
  • 编写定时任务:
*/1 * * * * sh /data/runlog.sh //分 时 日 月 周 命令

4.修改脚本 支持按月分类

LOGPATH=/usr/local/nginx/logs/zcom.access.log //日志文件
BASEPATH=/data/$(date -d yesterday +%Y%m%) //日志切换目录

bak=$BASEPATH/$(date -d yesterday +%d%H%M).zcom.access.log //切换后日志目录+名称
#echo $bak //查看值

mkdir $BASEPATH //创建月份目录
mv $LOGPATH $bak //移动目录
touch $LOGPATH   //创建新文件

kill -USR1 `cat /usr/local/nginx/logs/nginx.pid` //更新nginx目录节点
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值