gpt4 book ai didi

将 Airflow 参数传递给 Shell 脚本

转载 作者:行者123 更新时间:2023-12-02 12:20:08 25 4
gpt4 key购买 nike

我正在尝试在 Airflow DAG 中调用 shell 脚本并传递一些参数,如下所述,

def load_data_parameters():
today_date = '{{ ds }}'
environment = config.get('common', 'env')
return today_date,environment

today_date,environment = load_data_parameters()

EdgeToRaw_Command ="./scripts/test.sh"

Test = BashOperator(
task_id= 'Test-Task',
bash_command=EdgeToRaw_Command,
params = {'env': environment},
dag=dag)

在 shell 脚本中只是尝试打印,

envi=$1
echo $envi

有人可以帮助解决这个问题,或者告诉我如何将参数传递给调用脚本来执行某些任务的 BashOperator。

最佳答案

在您的 shell 脚本中,您需要具有以下内容

envi={{params.env}}
echo $envi

基本上,无论您传递给 BashOperator 中的 params 参数,都需要由 {{params.PARAMETER_NAME}} 调用

编辑:

注意:您的“scripts”文件夹应与 Dag 文件位于同一文件夹中。因此,如果您的 dag 位于“/usr/local/airflow/dags”下,则您的“scripts”文件夹应该位于 dame 文件夹中。并且您需要在 bash_command 中传递相对路径,即“scripts/test.sh”

关于将 Airflow 参数传递给 Shell 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53522133/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com