Yandex Cloud
Search
Contact UsTry it for free
  • Customer Stories
  • Documentation
  • Blog
  • All Services
  • System Status
  • Marketplace
    • Featured
    • Infrastructure & Network
    • Data Platform
    • AI for business
    • Security
    • DevOps tools
    • Serverless
    • Monitoring & Resources
  • All Solutions
    • By industry
    • By use case
    • Economics and Pricing
    • Security
    • Technical Support
    • Start testing with double trial credits
    • Cloud credits to scale your IT product
    • Gateway to Russia
    • Cloud for Startups
    • Center for Technologies and Society
    • Yandex Cloud Partner program
    • Price calculator
    • Pricing plans
  • Customer Stories
  • Documentation
  • Blog
© 2026 Direct Cursus Technology L.L.C.
Yandex Managed Service for Sharded PostgreSQL
  • Getting started
    • All guides
    • Creating a cluster
    • Connecting to a database
    • Updating a cluster
    • Managing shards
    • Maintenance
    • Deleting a cluster
  • Access management
  • Pricing policy
  • Terraform reference
  • Monitoring metrics
  • Audit Trails events
  • Public materials
  • Release notes
  • FAQ

In this article:

  • Getting a list of maintenance jobs
  • Getting maintenance-related cluster logs
  • Postpone the planned maintenance
  • Starting scheduled maintenance immediately
  • Configuring a maintenance window
  1. Step-by-step guides
  2. Maintenance

Sharded PostgreSQL cluster maintenance

Written by
Yandex Cloud
Updated at March 5, 2026
  • Getting a list of maintenance jobs
  • Getting maintenance-related cluster logs
  • Postpone the planned maintenance
  • Starting scheduled maintenance immediately
  • Configuring a maintenance window

You can manage Managed Service for Sharded PostgreSQL cluster maintenance, including the following:

  • Getting a list of maintenance jobs
  • Getting cluster maintenance logs
  • Postponing scheduled maintenance
  • Starting scheduled maintenance immediately
  • Configuring a maintenance window

Getting a list of maintenance jobsGetting a list of maintenance jobs

  1. Go to Yandex Managed Service for Sharded PostgreSQL.
  2. Click the name of your cluster and select the Technical maintenance tab.

To view maintenance jobs with a specific status, click Status above the maintenance list and select the status you want from the drop-down menu. You can also find a maintenance job by its ID or job name using the search field above the list.

Click an ID to see how the maintenance job affects cluster availability. Look up Task details to see how the maintenance job affects users.

Getting maintenance-related cluster logsGetting maintenance-related cluster logs

  1. Navigate to the Yandex Managed Service for Sharded PostgreSQL service.
  2. Click the name of your cluster and select the Technical maintenance tab.
  3. Click the ID of the maintenance job you need.
  4. Click Task logs.

Postpone the planned maintenancePostpone the planned maintenance

Maintenance jobs with the Planned status have a specific scheduled date and time specified in the Start date column. You can reschedule them to a new date and time if needed.

Management console
CLI
REST API
gRPC API

To reschedule maintenance for a new date and time:

  1. Navigate to the Yandex Managed Service for Sharded PostgreSQL service.
  2. Click the name of your cluster and select the Technical maintenance tab.
  3. Click next to the maintenance job with the Planned status.
  4. In the drop-down menu, select Postpone.
  5. In the window that opens:
    • To postpone the maintenance until the next available window, click Next window and then Reschedule. This option is available if the cluster has a scheduled maintenance window configured.
    • To reschedule maintenance to a specific UTC date and time, click Choose date (UTC), then select a new date and time interval and click Reschedule.

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 options.

To reschedule maintenance for a new date and time:

  1. See the description of the CLI command for rescheduling maintenance:

    yc managed-sharded-postgresql cluster reschedule-maintenance --help
    
  2. To reschedule the maintenance to the next available window, run this command specifying the next-available-window reschedule type (available only in a cluster with a scheduled maintenance window). To reschedule the maintenance to a specific date and time, use the specific-time reschedule type:

    yc managed-sharded-postgresql cluster reschedule-maintenance <cluster_name_or_ID> \
       --reschedule-type <reschedule_type> \
       --delayed-until <timestamp>
    

    The timestamp must be in one of the following formats:

    • RFC-3339
    • HH:MM:SS
    • Number of hours and minutes by which to move the maintenance.

    For example, 2006-01-02T15:04:05Z, 15:04:05, 2h, or 3h30m ago. With the next-available-window reschedule type, you do not need to specify --delayed-until.

To reschedule maintenance for a new date and time:

  1. Get an IAM token for API authentication and put it into an environment variable:

    export IAM_TOKEN="<IAM_token>"
    
  2. Call the Cluster.RescheduleMaintenance method, e.g., via the following cURL request:

    curl \
    --request POST \
    --header "Authorization: Bearer $IAM_TOKEN" \
    --header "Content-Type: application/json" \
    --url 'https://mdb.api.cloud.yandex.net/managed-spqr/v1/clusters/<cluster_ID>:rescheduleMaintenance' \
    --data '{
                "rescheduleType": <reschedule_type>,
                "delayedUntil": <timestamp>
            }'
    

    Where rescheduleType is the reschedule type that can be one of the following values:

    • NEXT_AVAILABLE_WINDOW: Rescheduling maintenance to the next available window (only in clusters with a scheduled maintenance window).
    • SPECIFIC_TIME: Reschedule maintenance to a specific date and time.

    The timestamp must be in RFC-3339 format, e.g., 2006-01-02T15:04:05Z. With the NEXT_AVAILABLE_WINDOW reschedule type, you do not need to specify delayedUntil.

  3. Check the server response to make sure your request was successful.

  1. Get an IAM token for API authentication and put it into an environment variable:

    export IAM_TOKEN="<IAM_token>"
    
  2. Clone the cloudapi repository:

    cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapi
    

    Below, we assume that the repository contents reside in the ~/cloudapi/ directory.

  3. Call the ClusterService.RescheduleMaintenance method, for instance, via the following gRPCurl request:

    grpcurl \
      -format json \
      -import-path ~/cloudapi/ \
      -import-path ~/cloudapi/third_party/googleapis/ \
      -proto ~/cloudapi/yandex/cloud/mdb/spqr/v1/cluster_service.proto \
      -rpc-header "Authorization: Bearer $IAM_TOKEN" \
      -d '{
            "cluster_id": "<cluster_ID>",
            "reschedule_type": <reschedule_type>,
            "delayed_until": <timestamp>
          }' \
      mdb.api.cloud.yandex.net:443 \
      yandex.cloud.mdb.spqr.v1.ClusterService.RescheduleMaintenance
    

    Where reschedule_type is the reschedule type that can be one of the following values:

    • NEXT_AVAILABLE_WINDOW: Rescheduling maintenance to the next available window (only in clusters with a scheduled maintenance window).
    • SPECIFIC_TIME: Reschedule maintenance to a specific date and time.

    The timestamp must be in RFC-3339 format, e.g., 2006-01-02T15:04:05Z. With the NEXT_AVAILABLE_WINDOW reschedule type, you do not need to specify delayed_until.

  4. Check the server response to make sure your request was successful.

Starting scheduled maintenance immediatelyStarting 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.

Management console
CLI
REST API
gRPC API

To run a scheduled cluster maintenance job immediately:

  1. Navigate to the Yandex Managed Service for Sharded PostgreSQL service.
  2. Click the name of your cluster and select the Technical maintenance tab.
  3. Click next to the maintenance job you need.
  4. In the drop-down menu, select Carry out now.

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 options.

To run a scheduled cluster maintenance job immediately:

  1. See the description of the CLI command for rescheduling maintenance:

    yc managed-sharded-postgresql cluster reschedule-maintenance --help
    
  2. Run this command using the immediate reschedule type:

    yc managed-sharded-postgresql cluster reschedule-maintenance <cluster_name_or_ID> \
       --reschedule-type immediate
    

To run a scheduled cluster maintenance job immediately:

  1. Get an IAM token for API authentication and put it into an environment variable:

    export IAM_TOKEN="<IAM_token>"
    
  2. Call the Cluster.RescheduleMaintenance method, e.g., via the following cURL request:

    curl \
    --request POST \
    --header "Authorization: Bearer $IAM_TOKEN" \
    --header "Content-Type: application/json" \
    --url 'https://mdb.api.cloud.yandex.net/managed-spqr/v1/clusters/<cluster_ID>:rescheduleMaintenance' \
    --data '{
                "rescheduleType": "IMMEDIATE"
            }'
    
  3. Check the server response to make sure your request was successful.

  1. Get an IAM token for API authentication and put it into an environment variable:

    export IAM_TOKEN="<IAM_token>"
    
  2. Clone the cloudapi repository:

    cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapi
    

    Below, we assume that the repository contents reside in the ~/cloudapi/ directory.

  3. Call the ClusterService.RescheduleMaintenance method, for instance, via the following gRPCurl request:

    grpcurl \
      -format json \
      -import-path ~/cloudapi/ \
      -import-path ~/cloudapi/third_party/googleapis/ \
      -proto ~/cloudapi/yandex/cloud/mdb/spqr/v1/cluster_service.proto \
      -rpc-header "Authorization: Bearer $IAM_TOKEN" \
      -d '{
            "cluster_id": "<cluster_ID>",
            "reschedule_type": "IMMEDIATE"
          }' \
      mdb.api.cloud.yandex.net:443 \
      yandex.cloud.mdb.spqr.v1.ClusterService.RescheduleMaintenance
    
  4. Check the server response to make sure your request was successful.

Configuring a maintenance windowConfiguring a maintenance window

By default, maintenance can be scheduled for any time. You can choose a specific day of the week and hour to schedule maintenance. For example, you can choose the time when the cluster is least busy.

Warning

Selecting a new maintenance interval will automatically cancel any scheduled maintenance outside the new interval.

Management console
CLI
Terraform
REST API
gRPC API
  1. Navigate to the Yandex Managed Service for Sharded PostgreSQL service.
  2. Click the name of your cluster and select the Technical maintenance tab.
  3. Click Configure the maintenance window.
  4. In the window that opens:
    • To allow maintenance at any time, select arbitrary, which is also the default option.
    • To allow weekly maintenance at a specific time, select by schedule and specify the weekday 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 options.

  1. See the description of the CLI command for updating the maintenance window:

    yc managed-sharded-postgresql cluster update --help
    
  2. Run this command:

    yc managed-sharded-postgresql cluster update <cluster_name_or_ID> \
       --maintenance-window type=<maintenance_type>,`
                           `day=<day_of_week>,`
                           `hour=<hour>
    

    Where type is 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, or SUN.
      • hour: Hour of day (UTC), from 1 to 24.
  1. Open the current Terraform configuration file describing your infrastructure.

    For more on how to create this file, see Creating a cluster.

    For a complete list of configurable Managed Service for Sharded PostgreSQL cluster fields, see this Terraform provider guide.

  2. To set the maintenance window that will also apply to stopped clusters, add the maintenance_window section to the cluster description:

    resource "yandex_mdb_sharded_postgresql_cluster" "<cluster_name>" {
      ...
      maintenance_window {
        type = <maintenance_type>
        day  = <day_of_week>
        hour = <hour>
      }
      ...
    }
    

    Where:

    • type: Maintenance type. The possible values include:
      • ANYTIME: Anytime
      • WEEKLY: On a schedule
    • day: Day of week for the WEEKLY type, i.e., MON, TUE, WED, THU, FRI, SAT, or SUN.
    • hour: UTC hour for the WEEKLY type, from 1 to 24.
  3. Make sure the settings are correct.

    1. In the command line, navigate to the directory that contains the current Terraform configuration files defining the infrastructure.

    2. Run this command:

      terraform validate
      

      Terraform will show any errors found in your configuration files.

  4. Confirm resource changes.

    1. Run this command to view the planned changes:

      terraform plan
      

      If 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.

    2. If everything looks correct, apply the changes:

      1. Run this command:

        terraform apply
        
      2. Confirm updating the resources.

      3. Wait for the operation to complete.

  1. Get an IAM token for API authentication and put it into an environment variable:

    export IAM_TOKEN="<IAM_token>"
    
  2. Call the Cluster.Update method, e.g., via the following cURL request:

    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 updateMask parameter as a single comma-separated string.

    curl \
      --request PATCH \
      --header "Authorization: Bearer $IAM_TOKEN" \
      --header "Content-Type: application/json" \
      --url 'https://mdb.api.cloud.yandex.net/managed-spqr/v1/clusters/<cluster_ID>' \
      --data '{
                "updateMask": "maintenanceWindow",
                "maintenanceWindow": {
                  "weeklyMaintenanceWindow": {
                    "day": "<day_of_week>",
                    "hour": "<hour>"
                  }
                }
              }'
    

    Where:

    • updateMask: Comma-separated list of settings you want to update.

      Here, we provide only one setting.

    • maintenanceWindow: Maintenance window settings, applying to both running and stopped clusters. In maintenanceWindow, provide one of the following values:

      • anytime: Maintenance can be scheduled for any time.

      • weeklyMaintenanceWindow: Maintenance can only be scheduled for a specific day of week and hour:

        • day: Day of week in DDD format, i.e., MON, TUE, WED, THU, FRI, SAT, or SUN.
        • hour: Time of day (UTC) in HH format, from 1 to 24.
  3. Check the server response to make sure your request was successful.

  1. Get an IAM token for API authentication and put it into an environment variable:

    export IAM_TOKEN="<IAM_token>"
    
  2. Clone the cloudapi repository:

    cd ~/ && git clone --depth=1 https://github.com/yandex-cloud/cloudapi
    

    Below, we assume that the repository contents reside in the ~/cloudapi/ directory.

  3. Call the ClusterService.Update method, e.g., via the following gRPCurl request:

    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_mask parameter as an array of paths[] 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/mdb/spqr/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>"
              }
            }
          }' \
      mdb.api.cloud.yandex.net:443 \
      yandex.cloud.mdb.spqr.v1.ClusterService.Update
    

    Where:

    • update_mask: List of settings to update as an array of strings (paths[]).

      Here, we provide only one setting.

    • maintenance_window: Maintenance window settings, applying to both running and stopped clusters. In maintenance_window, provide one of the following values:

      • anytime: Maintenance can be scheduled for any time.

      • weekly_maintenance_window: Maintenance can only be scheduled for a specific day of week and hour:

        • day: Day of week in DDD format, i.e., MON, TUE, WED, THU, FRI, SAT, or SUN.
        • hour: Time of day (UTC) in HH format, from 1 to 24.
  4. Check the server response to make sure your request was successful.

Was the article helpful?

Previous
Managing shards
Next
Deleting a cluster
© 2026 Direct Cursus Technology L.L.C.