Airflow通过DAG文件定义任务调度,需满足文件命名、全局dag变量、必要导入等要求;用PythonOperator封装函数,设置依赖、重试、触发规则及敏感参数管理;支持本地调试与生产部署。

用 Airflow 实现 Python 任务的自动化调度,核心是把业务逻辑封装成可被 Airflow 管理的 Operator,再通过 DAG 定义执行顺序、触发条件和重试策略。它不直接运行脚本,而是调度“任务实例”,靠 Scheduler 和 Executor 协同驱动。
DAG 是 Airflow 的调度蓝图,本质是一个 Python 文件(通常放在 dags/ 目录下),需满足几个硬性要求:
etl_daily_job.py)dag = DAG(...),且变量名固定为 dag
from airflow import DAG、from airflow.operators.python import PythonOperator 等schedule_interval(新版推荐用 schedule)决定触发频率,支持 cron 表达式(如 "0 2 * * *" 表示每天凌晨2点)或 timedelta(如 timedelta(days=1))这是最常用的方式,适合已有现成的 Python 函数。Airflow 会在任务运行时调用它,并自动传入上下文(**context):
task1 = PythonOperator(task_id='run_clean', python_callable=clean_data))op_kwargs 字典(如 op_kwargs={"table": "users", "days_back": 7}),函数签名要匹配context["ti"].xcom_pull(task_ids="upstream_task"))time.sleep(300)),应拆成多个短任务或改用 TimeDeltaSensor 等传感器任务不是孤立运行的,DAG 要明确谁先谁后、失败怎么处理:
立即学习“Python免费学习笔记(深入)”;
或 设置上下游(如 extract >> transform >> load),也可用 set_downstream() 方法
retries=3 指定失败后重试次数;retry_delay=timedelta(minutes=5) 控制重试间隔trigger_rule="all_success"(默认)表示所有上游成功才运行;换成 "all_done" 可让任务无论上游成败都执行(适合清理类任务)BaseHook.get_connection("my_db").password 获取别等部署到生产才发现问题:
airflow dags list 看是否识别;airflow tasks list my_dag_id 查任务;airflow tasks test my_dag_id task_name 2024-01-01 模拟单次运行(不走调度器,纯本地执行)dags/ 目录,无需重启服务(但语法错误会导致 DAG 显示为「paused」并报红)基本上就这些。Airflow 强大但不复杂,关键在把逻辑切分成职责清晰的小任务,再用 DAG 连起来。写完一个能跑通的最小 DAG,后面扩展就顺了。
以上就是Python使用Airflow实现自动化任务调度的构建方式【教程】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号