Python编写定时执行脚本

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

day_log_file = '/root/logdir/info.kongdao.log'
req_count_log_path = '/root/logdir/request/req_count/'

# 定时任务,每天晚上分析当天的日志数据
def log_job():
    # 执行shell命令获取当日请求数
    req_count_command = 'grep "发起查询请求" ' + day_log_file + ' | wc -l'
    req_count_out = subprocess.check_output(req_count_command, shell=True, encoding='UTF-8')
    req_count = req_count_out.strip()
    # 当天日期
    date = str(datetime.date.today())
    format_date = date.replace('-', '')
    # 获取文件的创建时间
    infos = os.stat(day_log_file)
    ctime = time.strftime('%Y%m%d', time.localtime(infos.st_ctime))
    # request计数存储的文件名
    file_name = format_date[:6]
    # 若info.kongdao.log不是当天的日志,则当天请求数量为0
    if format_date != ctime:
        req_count = '0'
    req_count_log = date + ' ' + req_count
    record_log_command = "echo '" + req_count_log + "' >>" + req_count_log_path + file_name
    subprocess.check_output(record_log_command, shell=True, encoding='UTF-8')


if __name__ == '__main__':
    sched = BlockingScheduler()
    # 每天23:55执行
    sched.add_job(log_job, 'cron', hour=23, minute=55)
    sched.start()
  • 0
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周景洛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值