airflow.providers.cncf.kubernetes.utils.pod_manager
¶
Launches PODs
Module Contents¶
Classes¶
Possible pod phases |
|
Helper class for creating, monitoring, and otherwise interacting with Kubernetes pods |
Functions¶
|
Check if an Exception indicates a transient error and warrants retrying |
|
Examines V1Pod |
- exception airflow.providers.cncf.kubernetes.utils.pod_manager.PodLaunchFailedException[source]¶
Bases:
airflow.exceptions.AirflowException
When pod launching fails in KubernetesPodOperator.
- airflow.providers.cncf.kubernetes.utils.pod_manager.should_retry_start_pod(exception)[source]¶
Check if an Exception indicates a transient error and warrants retrying
- class airflow.providers.cncf.kubernetes.utils.pod_manager.PodPhase[source]¶
Possible pod phases See https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#pod-phase.
- airflow.providers.cncf.kubernetes.utils.pod_manager.container_is_running(pod, container_name)[source]¶
Examines V1Pod
pod
to determine whethercontainer_name
is running. If that container is present and running, returns True. Returns False otherwise.
- class airflow.providers.cncf.kubernetes.utils.pod_manager.PodManager(kube_client=None, in_cluster=True, cluster_context=None)[source]¶
Bases:
airflow.utils.log.logging_mixin.LoggingMixin
Helper class for creating, monitoring, and otherwise interacting with Kubernetes pods for use with the KubernetesPodOperator
- await_pod_start(self, pod, startup_timeout=120)[source]¶
Waits for the pod to reach phase other than
Pending
- Parameters
pod (kubernetes.client.models.v1_pod.V1Pod) --
startup_timeout (int) -- Timeout (in seconds) for startup of the pod (if pod is pending for too long, fails task)
- Returns
- Return type
None
- follow_container_logs(self, pod, container_name)[source]¶
Follows the logs of container and streams to airflow logging. Returns when container exits.
Note
read_pod_logs()
follows the logs, so we shouldn't necessarily need to loop as we do here. But in a long-running process we might temporarily lose connectivity. So the looping logic is there to let us resume following the logs.
- await_pod_completion(self, pod)[source]¶
Monitors a pod and returns the final state
- Parameters
pod (kubernetes.client.models.v1_pod.V1Pod) -- pod spec that will be monitored
- Returns
Tuple[State, Optional[str]]
- Return type
kubernetes.client.models.v1_pod.V1Pod
- container_is_running(self, pod, container_name)[source]¶
Reads pod and checks if container is running