当前位置: 移动技术网 > 科技>操作系统>Linux > Nginx-日志切割

Nginx-日志切割

2018年11月08日  | 移动技术网科技  | 我要评论

评课稿范文,九阴真经锌锭,平庸男子大作战

nginx 日志切割

ps:nginx日志切割可以通过两种方式进行切割,日志logrotate,脚本

方法一:通过logrotate切割

个人感觉配置麻烦,且结合自己这边的项目的环境的复杂,所以就不使用这种方式。这里我也就不写了

可以参考:https://www.cnblogs.com/ilanni/p/5365420.html

方法二:通过shell脚本切割

1、编写shell脚本

#!/bin/bash
#此脚本用于自动分割nginx的日志,包括access.log和error.log
#每天00:00执行此脚本 将前一天的access.log重命名为access-xxxx-xx-xx.log格式,并重新打开日志文件
#nginx日志文件所在目录
log_path=/opt/nginx/logs
#获取昨天的日期
yesterday=$(date -d "yesterday" +%y-%m-%d)
#获取pid文件路径
pid=/var/run/nginx/nginx.pid
#分割日志
mv ${log_path}access.log ${log_path}access-${yesterday}.log
mv ${log_path}error.log ${log_path}error-${yesterday}.log
#向nginx主进程发送usr1信号,重新打开日志文件
kill -usr1 `cat ${pid}`

2、配置crontab每天凌晨00:00定时执行这个脚本

crontab -e
# 输入以下内容并保存
00 00 * * * /bin/bash /opt/nginx/sbin/cut_nginx_log.sh

方法三:通过python脚本切割

鉴于这种乱情况,日志目录下面还有多个项目的日志,且分别保存在不同的文件下面(下面又分为测试环境的日志,预发布环境的日志),使用shell脚本就不怎么好写,我就采取了通过python来实现

脚本:

import os, sys, datetime,re

# nginx日志存放的路径
nginxlogpath="/opt/nginx-1.9.5/logs/"
# 获取昨天的日期
yesterday = (datetime.date.today() + datetime.timedelta(days = -1)).strftime("%y-%m-%d")
# nginx启动的pid文件
pid = "/var/run/nginx.pid"


def cutnginxlog(path):
    """
    切割nginx日志函数
    :param path: 日志文件的第一级目录
    :return: 
    """
    loglist = os.listdir(path)    # 判断传入的path是否是目录
    for logname in loglist:      # 循环处理目录里面的文件
        logabspath = os.path.join(path, logname)
        if os.path.isdir(logabspath):   # 如果是目录,递归调用自己,继续处理
            cutnginxlog(logabspath)
        else:         # 如果是日志文件,就进行处理
            # 分割日志
            re_num = re.compile(r'^[a-za-z]')
            # 判断日志文件是否是字母开头,如果是日期开头就不切割
            if re_num.search(logname):
                lognewname = yesterday + "_" + logname          # 新日志文件名称列如:2018-11-8_access.log
                oldlogpath = os.path.join(path, logname)        # 旧日志文件绝对路径
                newlogpath = os.path.join(path, lognewname)     # 新日志文件绝对路径
                os.rename(oldlogpath, newlogpath)

    cmd = " kill -usr1 `cat %s` "% pid
    res = os.system(cmd)
    if res != 0:
        return "重新加载nginx失败"
cutnginxlog(nginxlogpath)

计划任务:

# crontab -e

30 02 * * * /usr/bin/python3.5 /opt/nginx-1.9.5/sbin/cut_nginx_log.py

切割后的效果图:

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网