Yandex Managed Service for Apache Airflow™ cluster maintenance
Managed Service for Apache Airflow™ cluster maintenance can be managed.
Getting a list of maintenances
- Navigate to the folder dashboard and select Managed Service for Apache Airflow™.
- Click the name of your cluster and open the Technical maintenance tab.
To view maintenances with a particular status, click Status above the list of maintenances and select the status of interest from the drop-down menu. To find a specific maintenance, enter its ID or task name in the field above the list of maintenances.
Getting cluster maintenance logs
- Navigate to the folder dashboard and select Managed Service for Apache Airflow™.
- Click the name of your cluster and open the Technical maintenance tab.
- Click the maintenance ID you need.
- Click Task logs.
Moving scheduled maintenance
Maintenance sessions with the Planned status are scheduled for the date and time specified in the Start date column. You can move them to a new date and time if needed.
To move a maintenance to a new date and time:
-
Navigate to the folder dashboard and select Managed Service for Apache Airflow™.
-
Click the name of your cluster and open the Technical maintenance tab.
-
Click
next to the maintenance with the Planned status. -
In the drop-down menu, select
Postpone. -
In the window that opens:
- To move a maintenance forward to the next maintenance window, click Next window and then Reschedule.
- To move a maintenance forward or backward to a specific UTC date and time, click Choose date (UTC), then select a new date and time and click Reschedule.
Performing scheduled maintenance immediately
If you need to, you can perform a maintenance with the Planned status immediately without waiting for the time specified in the Start date column.
To perform a scheduled cluster maintenance immediately:
- Navigate to the folder dashboard and select Managed Service for Apache Airflow™.
- Click the name of your cluster and open the Technical maintenance tab.
- Click
next to the maintenance. - In the drop-down menu, select
Carry out now.
Configuring a maintenance window
By default, maintenance can be scheduled to any time slot. You can select a particular day of week and hour for the maintenance. For example, you can specify the time when the cluster is least loaded.
Warning
By selecting a new maintenance interval you will automatically cancel scheduled maintenance unless it falls within the new interval.
-
Navigate to the folder dashboard and select Managed Service for Apache Airflow™.
-
Click the name of your cluster and open the Technical maintenance tab.
-
Click
Configure the maintenance window. -
In the window that opens:
- To allow maintenance at any time, select arbitrary (default).
- To allow maintenance once a week at a particular time, select by schedule and specify the day of week and hour in UTC.
If you do not have the Yandex Cloud CLI installed yet, install and initialize it.
By default, the CLI uses the folder specified when creating the profile. To change the default folder, use the yc config set folder-id <folder_ID> command. You can also set a different folder for any specific command using the --folder-name or --folder-id parameter.
-
View the description of the CLI command for updating the maintenance window:
yc managed-airflow cluster update --help -
Run this command:
yc managed-airflow cluster update <cluster_name_or_ID> \ --maintenance-window type=<maintenance_type>,` `day=<day_of_week>,` `hour=<hour>Where
typeis the maintenance type:anytime: At any time (default).weekly: On a schedule. For this value, also specify the following:day: Day of week, i.e.,MON,TUE,WED,THU,FRI,SAT, orSUN.hour: Hour of day (UTC), from1to24.
You can get the cluster name and ID with the list of clusters in the folder.
-
Open the current Terraform configuration file that defines your infrastructure.
For more information about creating this file, see this guide.
-
To set up a maintenance window, add the
maintenance_windowsection to the cluster description:resource "yandex_airflow_cluster" "<cluster_name>" { ... maintenance_window = { type = "<maintenance_type>" day = "<day_of_week>" hour = <hour> } ... }Where:
type: Maintenance type. The possible values include:ANYTIME: AnytimeWEEKLY: On a schedule
day: Day of week for theWEEKLYtype, i.e.,MON,TUE,WED,THU,FRI,SAT, orSUN.hour: UTC hour for theWEEKLYtype, from1to24.
-
Make sure the settings are correct.
-
In the command line, navigate to the directory that contains the current Terraform configuration files defining the infrastructure.
-
Run this command:
terraform validateTerraform will show any errors found in your configuration files.
-
-
Confirm updating the resources.
-
Run this command to view the planned changes:
terraform planIf you described the configuration correctly, the terminal will display a list of the resources to update and their parameters. This is a verification step that does not apply changes to your resources.
-
If everything looks correct, apply the changes:
-
Run this command:
terraform apply -
Confirm updating the resources.
-
Wait for the operation to complete.
-
-
-
Get an IAM token for API authentication and save it as an environment variable:
export IAM_TOKEN="<IAM_token>" -
Use the Cluster.Update method and send the following request, e.g., via cURL
:Warning
The API method will assign default values to all the parameters of the object you are modifying unless you explicitly provide them in your request. To avoid this, list the settings you want to change in the
updateMaskparameter as a single comma-separated string.curl \ --request PATCH \ --header "Authorization: Bearer $IAM_TOKEN" \ --header "Content-Type: application/json" \ --url 'https://airflow.api.cloud.yandex.net/managed-airflow/v1/clusters/<cluster_ID>' \ --data '{ "updateMask": "maintenanceWindow", "maintenanceWindow": { "weeklyMaintenanceWindow": { "day": "<day_of_week>", "hour": "<hour>" } } }'Where:
-
updateMask: List of parameters to update as a single string, separated by commas.Only one parameter is provided in this case.
-
maintenanceWindow: Maintenance window settings (including for disabled clusters). InmaintenanceWindow, provide one of the two parameters:-
anytime: Maintenance can take place at any time. -
weeklyMaintenanceWindow: Maintenance takes place once a week at the specified time:day: Day of week inDDDformat:MON,TUE,WED,THU,FRI,SAT, orSUN.hour: Time of day (UTC) inHHformat, from1to24.
-
You can get the cluster ID with the list of clusters in the folder.
-
-
View the server response to make sure your request was successful.
-
Get an IAM token for API authentication and save it as an environment variable:
export IAM_TOKEN="<IAM_token>" -
Clone the cloudapi
repository:cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapiBelow, we assume the repository contents are stored in the
~/cloudapi/directory. -
Use the ClusterService.Update call and send the following request, e.g., via gRPCurl
:Warning
The API method will assign default values to all the parameters of the object you are modifying unless you explicitly provide them in your request. To avoid this, list the settings you want to change in the
update_maskparameter as an array ofpaths[]strings.Format for listing settings
"update_mask": { "paths": [ "<setting_1>", "<setting_2>", ... "<setting_N>" ] }grpcurl \ -format json \ -import-path ~/cloudapi/ \ -import-path ~/cloudapi/third_party/googleapis/ \ -proto ~/cloudapi/yandex/cloud/airflow/v1/cluster_service.proto \ -rpc-header "Authorization: Bearer $IAM_TOKEN" \ -d '{ "cluster_id": "<cluster_ID>", "update_mask": { "paths": ["maintenance_window"] }, "maintenance_window": { "weekly_maintenance_window": { "day": "<day_of_week>", "hour": "<hour>" } } }' \ airflow.api.cloud.yandex.net:443 \ yandex.cloud.airflow.v1.ClusterService.UpdateWhere:
-
update_mask: List of parameters to update as an array ofpaths[]strings.Only one parameter is provided in this case.
-
maintenance_window: Maintenance window settings (including for disabled clusters). Inmaintenance_window, provide one of the two parameters:-
anytime: Maintenance can take place at any time. -
weekly_maintenance_window: Maintenance takes place once a week at the specified time:day: Day of week inDDDformat:MON,TUE,WED,THU,FRI,SAT, orSUN.hour: Time of day (UTC) inHHformat, from1to24.
-
You can get the cluster ID with the list of clusters in the folder.
-
-
View the server response to make sure your request was successful.