apscheduler

python 复制代码
from apscheduler.schedulers.background import BlockingScheduler
from apscheduler.triggers.cron import CronTrigger
import time
from apscheduler.triggers.interval import IntervalTrigger
from config.config_util import get_yaml_cfg_by_key
from tools import db_util
from tools.logger_util import logger
from tools.request_util import trigger_batch

db_cfg = get_yaml_cfg_by_key("check_db")


class TaskScheduler:
    def __init__(self):
        self.scheduler = BlockingScheduler()
        self.job = None

    def get_scheduler_cfg(self, config_id):
        sql = f"select config_value from cmap_qc_config where config_id = '{config_id}' "
        one = db_util.fetch_pg(db_cfg, sql, fetchall=False)
        cron_expression, is_enabled = one[0]['cron_expression'], one[0]['enabled']
        return cron_expression, bool(is_enabled)

    def start_or_update_task(self, config_id):
        cron_expression, enabled = self.get_scheduler_cfg(config_id)
        if enabled:
            cron_trigger = CronTrigger.from_crontab(cron_expression)
            if self.job:
                if self.job.trigger.fields != cron_trigger.fields:
                    self.job.remove()
                    self.job = self.scheduler.add_job(self.pdb_check, trigger=cron_trigger)
                    logger.info(f"任务已更新,新的 cron 表达式为:{cron_expression}")
                else:
                    logger.info(f"不需要更新,新的 cron 表达式为:{cron_expression}")
            else:
                self.job = self.scheduler.add_job(self.pdb_check, trigger=cron_trigger)
                logger.info(f"任务已启动,cron 表达式为:{cron_expression}")
            logger.info(f"{self.job.next_run_time=}")
        else:
            if self.job:
                self.job.remove()
                self.job = None
                logger.info("任务已停止。")
            else:
                logger.info("任务未启动,数据库配置为禁用。")

    def pdb_check(self):
        logger.info(f"任务正在执行,当前时间:{time.strftime('%Y-%m-%d %H:%M:%S')}")
        trigger_batch_res = trigger_batch()
        logger.info(f"{trigger_batch_res=}")

    def shutdown(self):
        self.scheduler.shutdown(wait=False)
        logger.info("调度器已关闭。")


def start_scheduler():
    task_scheduler = TaskScheduler()
    # task_scheduler.scheduler.add_job(task_scheduler.start_or_update_task, args=["pdb_check_scheduler"],
    #                                  trigger=CronTrigger(second="*/5"))
    # task_scheduler.scheduler.add_job(task_scheduler.start_or_update_task, args=["pdb_check_scheduler"],
    #                                  trigger=IntervalTrigger(minutes=1))
    task_scheduler.scheduler.add_job(task_scheduler.start_or_update_task, args=["pdb_check_scheduler"],
                                     trigger=IntervalTrigger(minutes=30))
    logger.info("starting....")
    task_scheduler.scheduler.start()
    # try:
    #     # print("调度器已启动,按 Ctrl+C 退出。")
    #     while True:
    #         time.sleep(10)
    # except KeyboardInterrupt:
    #     task_scheduler.shutdown()


# 测试代码
if __name__ == "__main__":
    start_scheduler()
相关推荐
Katecat996631 小时前
YOLO11分割算法实现甲状腺超声病灶自动检测与定位_DWR方法应用
python
Evand J1 小时前
TDOA(到达时间差)的GDOP和CRLB计算的MATLAB例程,论文复现,附参考文献。GDOP:几何精度因子&CRLB:克拉美罗下界
开发语言·matlab·tdoa·crlb·gdop
野犬寒鸦1 小时前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
云姜.1 小时前
java抽象类和接口
java·开发语言
xyq20241 小时前
Pandas 安装指南
开发语言
xixixin_1 小时前
【JavaScript 】从 || 到??:JavaScript 空值处理的最佳实践升级
开发语言·javascript·ecmascript
玩大数据的龙威1 小时前
农经权二轮延包—各种地块示意图
python·arcgis
ZH15455891311 小时前
Flutter for OpenHarmony Python学习助手实战:数据库操作与管理的实现
python·学习·flutter
belldeep2 小时前
python:用 Flask 3 , mistune 2 和 mermaid.min.js 10.9 来实现 Markdown 中 mermaid 图表的渲染
javascript·python·flask
喵手2 小时前
Python爬虫实战:电商价格监控系统 - 从定时任务到历史趋势分析的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·电商价格监控系统·从定时任务到历史趋势分析·采集结果sqlite存储