| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- # -*- coding: utf-8 -*-
- from sqlalchemy import Boolean, String, Integer, Text, ForeignKey
- from sqlalchemy.orm import Mapped, mapped_column, relationship
- from app.core.base_model import ModelMixin, UserMixin
- class JobModel(ModelMixin, UserMixin):
- """
- 定时任务调度表
- - 0: 运行中
- - 1: 暂停中
- """
- __tablename__: str = 'app_job'
- __table_args__: dict[str, str] = ({'comment': '定时任务调度表'})
- __loader_options__: list[str] = ["job_logs", "created_by", "updated_by"]
- name: Mapped[str | None] = mapped_column(String(64), nullable=True, default='', comment='任务名称')
- jobstore: Mapped[str | None] = mapped_column(String(64), nullable=True, default='default', comment='存储器')
- executor: Mapped[str | None] = mapped_column(String(64), nullable=True, default='default', comment='执行器:将运行此作业的执行程序的名称')
- trigger: Mapped[str] = mapped_column(String(64), nullable=False, comment='触发器:控制此作业计划的 trigger 对象')
- trigger_args: Mapped[str | None] = mapped_column(Text, nullable=True, comment='触发器参数')
- func: Mapped[str] = mapped_column(Text, nullable=False, comment='任务函数')
- args: Mapped[str | None] = mapped_column(Text, nullable=True, comment='位置参数')
- kwargs: Mapped[str | None] = mapped_column(Text, nullable=True, comment='关键字参数')
- coalesce: Mapped[bool] = mapped_column(Boolean, nullable=True, default=False, comment='是否合并运行:是否在多个运行时间到期时仅运行作业一次')
- max_instances: Mapped[int] = mapped_column(Integer, nullable=True, default=1, comment='最大实例数:允许的最大并发执行实例数')
- start_date: Mapped[str | None] = mapped_column(String(64), nullable=True, comment='开始时间')
- end_date: Mapped[str | None] = mapped_column(String(64), nullable=True, comment='结束时间')
-
- # 关联关系
- job_logs: Mapped[list['JobLogModel'] | None] = relationship(
- back_populates="job",
- lazy="selectin"
- )
- class JobLogModel(ModelMixin):
- """
- 定时任务调度日志表
- """
- __tablename__: str = 'app_job_log'
- __table_args__: dict[str, str] = ({'comment': '定时任务调度日志表'})
- __loader_options__: list[str] = ["job"]
- job_name: Mapped[str] = mapped_column(String(64), nullable=False, comment='任务名称')
- job_group: Mapped[str] = mapped_column(String(64), nullable=False, comment='任务组名')
- job_executor: Mapped[str] = mapped_column(String(64), nullable=False, comment='任务执行器')
- invoke_target: Mapped[str] = mapped_column(String(500), nullable=False, comment='调用目标字符串')
- job_args: Mapped[str | None] = mapped_column(String(255), nullable=True, default='', comment='位置参数')
- job_kwargs: Mapped[str | None] = mapped_column(String(255), nullable=True, default='', comment='关键字参数')
- job_trigger: Mapped[str | None] = mapped_column(String(255), nullable=True, default='', comment='任务触发器')
- job_message: Mapped[str | None] = mapped_column(String(500), nullable=True, default='', comment='日志信息')
- exception_info: Mapped[str | None] = mapped_column(String(2000), nullable=True, default='', comment='异常信息')
-
- # 任务关联
- job_id: Mapped[int | None] = mapped_column(
- ForeignKey('app_job.id', ondelete="CASCADE"),
- nullable=True,
- index=True,
- comment='任务ID'
- )
-
- job: Mapped["JobModel | None"] = relationship(
- back_populates="job_logs",
- lazy="selectin"
- )
|