通过python编写定时任务压缩日志文件

51 篇文章 0 订阅
6 篇文章 0 订阅
# -*- coding:utf-8 -*-
# !/usr/bin/env python3
# name : Alenx

'''
通过python编写定时任务压缩日志文件
nohup python compressLog.py > my.log &

'''

from apscheduler.schedulers.blocking import BlockingScheduler
import datetime
import time
import os
import zipfile

import logging

logging.basicConfig(level=logging.DEBUG,
                    format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
                    datefmt='%a, %d %b %Y %H:%M:%S',
                    filename='myapp.log',
                    filemode='w')

# 定义一个StreamHandler,将INFO级别或更高的日志信息打印到标准错误,并将其添加到当前的日志处理对象#
console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
console.setFormatter(formatter)
logging.getLogger('').addHandler(console)

root_path = "/usr/local/tomcat/logs/"


def zip_files(zip_src):
    logging.info("begin zip ...")
    if (os.path.exists(root_path + zip_src) == False):
        logging.info(zip_src + " not found")
        return
    f = zipfile.ZipFile(root_path + zip_src + ".zip", 'w', zipfile.ZIP_DEFLATED)
    f.write(root_path + zip_src)
    f.close()
    logging.info("zip " + zip_src + " done")
    os.remove(root_path + zip_src)


def tick():
    logging.info('Tick! The time is: %s' % datetime.datetime.now())
    now = datetime.datetime.now()
    delta = datetime.timedelta(days=-1)  # 获取前一天的日期
    n_days = now + delta
    yestoday = n_days.strftime('%Y-%m-%d')
    catalina_out = "catalina." + yestoday + ".out"
    zip_files(catalina_out)


if __name__ == '__main__':
    scheduler = BlockingScheduler()
    scheduler.add_job(tick, 'cron', hour='2')  # 每天两点执行
    # print('Press Ctrl+{0} to exit'.format('Break' if os.name == 'nt' else 'C'))
    try:
        scheduler.start()
    except (KeyboardInterrupt, SystemExit):
        scheduler.shutdown()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值