Source code for airflow.providers.cncf.kubernetes.backcompat.pod
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
"""Classes for interacting with Kubernetes API"""
from kubernetes.client import models as k8s
[docs]class Resources:
"""backwards compat for Resources"""
[docs] __slots__ = (
'request_memory',
'request_cpu',
'limit_memory',
'limit_cpu',
'limit_gpu',
'request_ephemeral_storage',
'limit_ephemeral_storage',
)
"""
:param request_memory: requested memory
:type request_memory: str
:param request_cpu: requested CPU number
:type request_cpu: float | str
:param request_ephemeral_storage: requested ephemeral storage
:type request_ephemeral_storage: str
:param limit_memory: limit for memory usage
:type limit_memory: str
:param limit_cpu: Limit for CPU used
:type limit_cpu: float | str
:param limit_gpu: Limits for GPU used
:type limit_gpu: int
:param limit_ephemeral_storage: Limit for ephemeral storage
:type limit_ephemeral_storage: float | str
"""
def __init__(
self,
request_memory=None,
request_cpu=None,
request_ephemeral_storage=None,
limit_memory=None,
limit_cpu=None,
limit_gpu=None,
limit_ephemeral_storage=None,
):
self.request_memory = request_memory
self.request_cpu = request_cpu
self.request_ephemeral_storage = request_ephemeral_storage
self.limit_memory = limit_memory
self.limit_cpu = limit_cpu
self.limit_gpu = limit_gpu
self.limit_ephemeral_storage = limit_ephemeral_storage
[docs] def to_k8s_client_obj(self):
"""
Converts to k8s object.
@rtype: object
"""
limits_raw = {
'cpu': self.limit_cpu,
'memory': self.limit_memory,
'nvidia.com/gpu': self.limit_gpu,
'ephemeral-storage': self.limit_ephemeral_storage,
}
requests_raw = {
'cpu': self.request_cpu,
'memory': self.request_memory,
'ephemeral-storage': self.request_ephemeral_storage,
}
limits = {k: v for k, v in limits_raw.items() if v}
requests = {k: v for k, v in requests_raw.items() if v}
resource_req = k8s.V1ResourceRequirements(limits=limits, requests=requests)
return resource_req
[docs]class Port:
"""POD port"""
[docs] __slots__ = ('name', 'container_port')
def __init__(self, name=None, container_port=None):
"""Creates port"""
self.name = name
self.container_port = container_port
[docs] def to_k8s_client_obj(self):
"""
Converts to k8s object.
:rtype: object
"""
return k8s.V1ContainerPort(name=self.name, container_port=self.container_port)