Configure component size limits
Astronomer Software allows you to customize the minimum and maximum sizes of most Astronomer platform and Airflow components.
You can configure the CPU and memory resources of Airflow components through the Astro UI or with the Houston API, in either Astro Units (AU’s) or Custom Resources, when CPU and memory are not a ratio of each other.
Astro Units (AU’s)
You can increase or decrease resources on Astro by units of size know as AU’s (Astro Units). Adding or removing an AstroUnit changes a Deployment’s size by changing the following:
- the size of a component by one-tenth of a v-core
- the size of the component by 384Mi of memory
- the limit of connections to the Postgres server by half of a connection
- the limit of connections used internally by Airflow to the database connection pooler by 5
- the size of the deployment-namespace’s overall cumulative limits (ResourceQuota and LimitRange) by one-tenth of a v-core and 834Mi of memory.
- the limit of Pods in the namespace by one Pod (ResourceQuota)
Configure Deployment-level limits for individual Pod sizes
You can use astronomer.houston.config.deployments.maxPodAu
to configure the maximum size any individual pod can be.
Configure Deployment-level limits for resource usage
Astronomer Software limits the amount of resources that can be used by all pods in a Deployment by creating and managing a LimitRange
and ResourceQuota
for the namespace associated with each Deployment.
These values are automatically adjust to account for the resource requirements of various components.
You can add additional resources, beyond the standard amount allocated based on the resource-requirements of standing components, to the LimitRange
and ResourceQuota
. Add resources by configuring astronomer.houston.config.deployments.maxExtraAu
to account for the requirements of KubernetesExecutor and KubernetesPodOperator tasks.
Configure the sizes of individual Deployment-level components
Components represent different parts of the Astronomer Software Deployment. You can customize the default configuration for a component by defining it in astronomer.houston.config.deployments.components
.
A list of configurable components and options is provided in Configurable Components.
When defining components, you must include the full definition of the component in the list entry after the components key, instead of only the components you want to define.
For example, to increase the maximum size a Celery worker task from 30 AU (3 Vcpu/11.5Gi) to 50AU (3 Vcpu/192Gi), add the full Celery worker component definition to astronomer.houston.config.deployments.components
in your values.yaml
with a higher limit (defined in AUs):
Configurable Components
Configurable components include:
Airflow Scheduler
Airflow Webserver
StatsD
Database Connection Pooler (PgBouncer)
Celery Diagnostic Web Interface (Flower)
Redis
Celery Workers
Triggerer
Manage Kubernetes worker CPU and memory with global platform config
You can use workers.resources.enabled
for the KubernetesExecutor
to manage worker Pod CPU and memory allocations with a platform configuration. When set to false
, Astronomer Software ignores worker Pod CPU or memory allocations set in the API or UI. This allows you to control Pod resources with your own Kubernetes policies or admission controllers.
API/UI manages Pod resources (Default KubernetesExecutor configuration)
To configure the default behavior where the API and UI manage worker Pod CPU and memory resources for the KubernetesExecutor, use the following configuration:
Disable API/UI resource configuration
If you configure your KubernetesExecutor so that CPU and memory requests and limits are set outside of Astronomer Software, you must disable resource configuration set with the Astronomer Software API/UI. To disable the Astronomer Software UI/API configuration, add the resources.enabled: false
flag to your values.yaml
file. This ensures that Software applies the worker resource settings exclusively from your preferred source, such as Pod mutation hooks or Pod configuration files. The following configuration sets them as an empty dict
.
Existing deployments are unchanged unless you update this setting.
Configure the size of KubernetesExecutor task pods
Kubernetes Executor task pods are defined at the task level when the DAG passes resource requests as part of executor_config
into the Operator. When not defined, these tasks default to using 1 AU, which is one-tenth of a Vcpu/384 Mi of memory. This means that when you define resource requests or limits for CPU and memory, ensure the maximum pod size is large enough to avoid errors during pod creation.
maxExtraAu
to support your desired level of resourcing and concurrency.The following example demonstrates how to configure resource limits and requests:
Note that KubernetesExecutor task pods are limited to the LimitRanges
and quotas
defined within the pod namespace.
Customize Astro Units (AU’s)
Configurable options include:
astronomer.houston.config.deployments.astroUnit.cpu
- the amount an AU contributes to the size of a component, in thousandths of a vCPU, and the size of theLimitRange
orResourceQuota
, defaults to100
.astronomer.houston.config.deployments.astroUnit.memory
- the amount an AU contributes to the size of a component, in Mi, and the size of theLimitRange
orResourceQuota
, set to384
by default.astronomer.houston.config.deployments.astroUnit.pods
- the amount an AU contributes to the maximum amount of pods permitted byResourceQuota
, set to1
by default.astronomer.houston.config.deployments.astroUnit.actualConns
- the amount an AU contributes to the limit of connections to the Postgres server, set to0.5
by default.astronomer.houston.config.deployments.astroUnit.airflowConns
- The amount an AU contributes to the limit of connections used internally by Airflow to the database connection pooler, set to5
by default.
The following code example shows how to set the resources per individual AU: