dimberman commented on a change in pull request #6377: AIRFLOW-5589 monitor 
pods by labels instead of names
URL: https://github.com/apache/airflow/pull/6377#discussion_r337026142
 
 

 ##########
 File path: airflow/contrib/operators/kubernetes_pod_operator.py
 ##########
 @@ -23,6 +25,28 @@
 from airflow.utils.state import State
 
 
+def create_labels_for_pod(context):
+    """
+    Generate labels for the pod s.t. we can track it in case of Operator crash
+    :param context:
+    :return:
+    """
+    labels = {
+        'dag_id': context['dag'].dag_id,
+        'task_id': context['task'].task_id,
+        'exec_date': context['ts']
+    }
+    # In the case of sub dags this is just useful
+    if context['dag'].parent_dag:
+        labels['parent_dag_id'] = context['dag'].parent_dag.dag_id
+    # Replace unsupported characters with dashes & trim at 63 chars (max 
allowed)
+    for label_id, label in labels.items():
+        label = re.sub(r'[^-A-Za-z0-9_.]+', '-', label)[:63]
 
 Review comment:
   Agreed

----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
 
For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


With regards,
Apache Git Services

Reply via email to