Airflow KubernetesPodOperator - 使用 ConfigMap 值作为环境变量

时间:2021-03-23 09:13:21

标签: kubernetes airflow kubernetespodoperator

我有一个名为 test 的 Kubernetes ConfigMap,其中包含一个带有某个值的键 foobar。我想在环境变量中使用该键的值。

import datetime
import os
from airflow import models
from airflow.contrib.kubernetes.volume import Volume
from airflow.contrib.kubernetes.volume_mount import VolumeMount
from airflow.contrib.operators import kubernetes_pod_operator

YESTERDAY = datetime.datetime.now() - datetime.timedelta(days=1)

cm_test = ['test']

volume_mount = VolumeMount('test',
                            mount_path='/config/',
                            sub_path=None,
                            read_only=False)
volume_config = {
    'configMap': {
        'name': 'test'
    }
}
volume = Volume(name='test', configs=volume_config)

with models.DAG(
        dag_id="test_env",
        schedule_interval=datetime.timedelta(days=1),
        start_date=YESTERDAY) as dag:

    
    kubenetes_template_ex = kubernetes_pod_operator.KubernetesPodOperator(
        task_id="test_env",
        name="test_env",
        namespace="foobar",
        image="bash",
        cmds=["printenv"],
        arguments=[],
        volumes=[volume],
        volume_mounts=[volume_mount],
        configmaps=cm_test,
        env_vars={
            'MY_ENV_VAR': '/config/foobar'
        }
    )

工作原理:ConfigMap 在安装的卷中可用,因此我可以执行 ls /config 并显示 foobar

什么不起作用:我想使用已安装的配置映射中 foobar 的值设置环境变量。当前代码不起作用,因为文本字符串值 /config/foobar 已提供给环境变量。

0 个答案:

没有答案