Changing the Apache Airflow version
 Amazon MWAA supports minor version upgrades and downgrades. This means you can update your environment from version x.4.z to x.5.z or from x.5.z to x.4.z. To perform a major version upgrade, for example from version 1.y.z to 2.y.z, you must create a new environment and migrate your resources. For more information about upgrading to a new major version of Apache Airflow, refer to Migrating to a new Amazon MWAA environment in the Amazon MWAA Migration Guide. 
During the upgrade or downgrade process, Amazon MWAA captures a snapshot of your environment metadata, upgrades or downgrades the workers, schedulers, the web server to the new Apache Airflow version, and finally restores the metadata database using the snapshot.
Before you upgrade or downgrade, make sure that your DAGs and other workflow resources are compatible with the new Apache Airflow version you're upgrading to. If you use requirements.txt to manage dependencies, you must also ensure that the dependencies you specify in your requirements are compatible with the new version.
Upgrade or downgrade your workflow resources
Whenever you're changing Apache Airflow versions, ensure that you reference the correct --constraint URL in your requirements.txt.
Warning
Specifying requirements that are incompatible with your target Apache Airflow version during an upgrade or downgrade might result in a lengthy rollback process to the previous version of Apache Airflow with the previous requirements version.
Migrate your workflow resources
- 
				Create a fork of the aws-mwaa-docker-images repository, and clone a copy of the Amazon MWAA local runner. 
- 
				Checkout to the branch of the aws-mwaa-docker-images repository that matches the version you are upgrading or downgrading to. 
- 
				To update your requirements.txt, follow the best practices we recommend in Managing Python dependencies, in the Amazon MWAA User Guide.
- 
				(Optional) To speed up the upgrade or downgrade process, clean up the environment's metadata database. Environments with a large amount of metadata can take significantly longer to upgrade. 
- 
				After you have successfully tested your workflow resources, copy your DAGs, requirements.txt, and plugins to your environment's Amazon S3 bucket.
You are now ready to edit the environment, specify a new Apache Airflow version, and start the update procedure.
Specify the new version
After you have completed updating your workflow resources to ensure compatibility with the new Apache Airflow version, do the following to edit environment details and specify the version of Apache Airflow that you want to upgrade to.
Note
When you perform an upgrade or downgrade, all tasks currently running on the environment are terminated during the procedure. The update procedure can take up to two hours, during which time your environment will be unavailable.
Specify a new version using the console
- 
				Open the Environments page on the Amazon MWAA console. 
- 
				From the Environments list, choose the environment that you want to upgrade or downgrade. 
- 
				On the environment page, choose Edit to edit the environment. 
- 
				In the Environment details section, for Airflow version, choose the Apache Airflow version number that you want to upgrade or downgrade the environment to from the dropdown list. 
- 
				Choose Next until you are on the Review and save page. 
- 
				On the Review and save page, review your changes, then choose Save. 
When you apply changes, your environment begins the upgrade or downgrade procedure. During this period, the status of your environment indicates what actions Amazon MWAA is taking, and whether the procedure is successful.
In a successful upgrade or downgrade scenario, the status will be UPDATING, then CREATING_SNAPSHOT as Amazon MWAA captures a backup of your metadata. Finally, the status will return first to UPDATING, then to AVAILABLE when the procedure is done.
If the environment fails to updrade or downgrade, your environment status will be ROLLING_BACK. If the rollback is successful, the status will first present UPDATE_FAILED, indicating that the update failed but the environment is available. If the rollback fails, the status will be UNAVAILABLE, indicating that you cannot access the environment.