When you create a new Astronomer Deployment, you can specify the exact amount of CPU and memory that power its core components using the Custom Resources resource strategy. Compared to using Astronomer Units (AU), which represent a fixed amount of CPU and memory, specifying custom resources gives you greater flexibility to define how your Deployments run. For example, you might need to allocate significantly more memory than CPU to your worker Pods if you need to run memory-intensive tasks, but at the same time you need more memory than CPU in your scheduler. In this scenario, using AUs isn’t sufficient because each component needs a different CPU to memory ratio. When a Deployment uses the Custom Resources resource strategy, Deployment Admins can specify the exact amount of CPU and memory they want each component to have without any scaling limitations. The resources you specify are used both as the limit and request values for the Pods running your components.Documentation Index
Fetch the complete documentation index at: https://astronomer-preview.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Set custom resource usage in the Software UI
To switch from using AU to using custom resource specifications:- In the Software UI, open your Deployment.
- In the Settings tab, change your Resource Strategy to Custom Resources.
- For each Software component, adjust the CPU and memory sliders to match your resource requirements. You can change the unit of the resource by clicking the dropdown menu that shows your current unit.
To create a Deployment through the Houston API that uses the custom resource strategy be default, set
astroUnitsEnabled: falsein yourDeployment creation mutation.Disable Astronomer Units (AUs) from Deployment resource configurations
To limit users to only configure Deployments using custom resources, set the following configuration in yourvalues.yaml file:
Set custom resources with Houston API
You can also switch from using AUs to custom resources specifications with the Houston API.Use Custom Resource Defaults
You can set custom defaults, limits and minimums for Airflow components and enable the use of the custom defaults with the feature flagcomponentsCustomDefaultsEnabled.
To enforce using custom resources only, you must enable custom defaults and disable Astro Units.
componentsCustomDefaultsEnabled is set to false and Astro Units are enabled, users must use the values defined in the config file for the AU defaults. This means when you use the following code example to define a component, Deployments are created respecting the AU resource definitions and the UI uses these defaults.
Configuration options
Use custom quotas if you need to guarantee or constrain Deployment resources beyond the system-determined logic. If you do not set quotas, the deployment will use platform default resource constraints.| Configuration Name | Component | Description | Default Value (if not set) | Accepted Values |
|---|---|---|---|---|
quotas | Deployment | Optional JSON object with custom resource quotas | Not set–platform logic is used | JSON object (requests and limits) |
quotas.requests.cpu | Deployment | CPU quota guaranteed (requested) | Platform default | Number (integer or float) |
quotas.requests.memory | Deployment | Memory quota guaranteed (requested) | Platform default | String, ("1920Mi", "2Gi") |
quotas.limits.cpu | Deployment | CPU quota maximum (limit) | Platform default | Number (integer or float) |
quotas.limits.memory | Deployment | Memory quota maximum (limit) | Platform default | String, ( "1920Mi", "28272Mi") |
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 aLimitRange 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.maxExtraCapacity and astronomer.houston.config.deployments.maxExtraPodCapacity to account for the requirements of KubernetesExecutor and KubernetesPodOperator tasks.
Configurable Components
Configurable components include:Airflow Scheduler
Airflow DAG processor
To enable a standalone DAG processor, set the
dagProcessorEnabled feature flag to true in your Houston API configuration in the config.yaml file:You can configure extra containers for the DAG processor in the
values.yaml file. For example: