Compartir a través de


Restauración de una instancia de servidor flexible de Azure Database for PostgreSQL mediante la CLI de Azure

Este script de la CLI de ejemplo restaura una única instancia de servidor flexible de Azure Database for PostgreSQL a un momento dado anterior.

Si no tiene una cuenta de Azure, cree una cuenta gratuita antes de comenzar.

Requisitos previos

Script de ejemplo

Para este script, use la CLI de Azure localmente, ya que tarda demasiado tiempo en ejecutarse en Cloud Shell.

Inicio de sesión en Azure

Use el siguiente script para iniciar sesión con una suscripción específica.

subscription="<subscriptionId>" # add subscription here

az account set -s $subscription # ...or use 'az login'

Para obtener más información, vea Establecimiento de la suscripción activa o Inicio de sesión de forma interactiva.

Ejecute el script.

# Restore an Azure Database for PostgreSQL server

# Variable block
let "randomIdentifier=$RANDOM*$RANDOM"
location="East US"
resourceGroup="msdocs-postgresql-rg-$randomIdentifier"
tag="backup-restore-postgresql"
server="msdocs-postgresql-server-$randomIdentifier"
sku="GP_Gen5_2"
restoreServer="restore-server$randomIdentifier"
login="azureuser"
password="Pa$$w0rD-$randomIdentifier"

echo "Using resource group $resourceGroup with login: $login, password: $password..."

# Create a resource group
echo "Creating $resourceGroup in $location..."
az group create --name $resourceGroup --location "$location" --tags $tag

# Create a PostgreSQL server in the resource group
# Name of a server maps to DNS name and is thus required to be globally unique in Azure.
echo "Creating $server in $location..."
az postgres server create --name $server --resource-group $resourceGroup --location "$location" --admin-user $login --admin-password $password --sku-name $sku

# Sleeping commands to wait long enough for automatic backup to be created
echo "Sleeping..."
sleep 10m

# Restore a server from backup to a new server
# To specify a specific point-in-time (in UTC) to restore from, use the ISO8601 format:
# restorePoint=“2021-07-09T13:10:00Z”
restorePoint=$(date +%s)
restorePoint=$(expr $restorePoint - 60)
restorePoint=$(date -d @$restorePoint +"%Y-%m-%dT%T")
echo $restorePoint

echo "Restoring $restoreServer"
az postgres server restore --name $restoreServer --resource-group $resourceGroup --restore-point-in-time $restorePoint --source-server $server

Limpieza de la implementación

Use el comando siguiente para quitar el grupo de recursos y todos los recursos asociados con él mediante el comando az group delete, a menos que tenga una necesidad constante de estos recursos. Algunos de estos recursos pueden tardar un tiempo en crearse, así como en eliminarse.

az group delete --name $resourceGroup

Referencia de ejemplo

Este script usa los comandos que se describen en la tabla siguiente:

Comando Notas
az group create (este comando se utiliza para crear un nuevo grupo en Azure) Crea un grupo de recursos en el que se almacenan todos los recursos.
az postgresql server create Crea una instancia de servidor flexible de Azure Database for PostgreSQL que hospeda las bases de datos.
az postgresql server restore Restaura un servidor desde una copia de seguridad.
az group delete (comando para eliminar grupos en Azure) Elimina un grupo de recursos, incluidos todos los recursos anidados.