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():
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))
file_name = format_date[:6]
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()
sched.add_job(log_job, 'cron', hour=23, minute=55)
sched.start()