Reiniciar o restablecer una instancia de Compute Engine


Este documento explica cómo reiniciar o restablecer una instancia de Compute Engine. Para obtener más información sobre los efectos de restablecer una instancia, así como las diferencias entre suspender, detener o restablecer una instancia, consulte Suspender, detener o restablecer instancias de Compute Engine .

Reiniciar o restablecer una instancia puede ayudar a garantizar un rendimiento y una estabilidad óptimos, o ayudar a resolver problemas como un sistema operativo invitado (SO) congelado, lento o que falla. Según el estado del sistema operativo invitado de su instancia, realice una de las siguientes acciones:

  • Reinicie la instancia . Si su sistema operativo invitado es lento o está congelado, reiniciar le da tiempo suficiente para terminar de ejecutar las tareas antes de apagarlo.

  • Restablecer la instancia . Restablezca una instancia solo si el sistema operativo invitado falló o no responde y no tiene otras opciones. Restablecer una instancia no permite que el sistema operativo invitado se apague limpiamente. Esta acción puede descartar datos no guardados y dañar los sistemas de archivos de cualquier disco.

Antes de comenzar

Roles requeridos

Para obtener los permisos que necesita para restablecer o reiniciar una instancia informática, solicite a su administrador que le otorgue el rol de IAM de Administrador de instancia informática (v1) ( roles/compute.instanceAdmin.v1 ) en la instancia. Para obtener más información sobre cómo otorgar roles, consulte Administrar el acceso a proyectos, carpetas y organizaciones .

Esta función predefinida contiene los permisos necesarios para restablecer o reiniciar una instancia informática. Para ver los permisos exactos que se requieren, expanda la sección Permisos requeridos :

Permisos requeridos

Se requieren los siguientes permisos para restablecer o reiniciar una instancia informática:

  • Para restablecer una instancia: compute.instances.reset
  • Para reiniciar una instancia desde su sistema operativo invitado: compute.instances.setMetadata

Es posible que también pueda obtener estos permisos con roles personalizados u otros roles predefinidos .

Reiniciar una instancia

Reiniciar una instancia informática permite que el sistema operativo invitado de la instancia finalice las tareas de ejecución antes de que Compute Engine envíe la señal de apagado ACPI. Esto ayuda a garantizar un apagado limpio del sistema operativo invitado.

Reiniciar una instancia borra la memoria utilizada por la instancia. Si está utilizando discos RAM con sus instancias y necesita conservar esos datos, haga una copia de seguridad de los datos antes de reiniciar la instancia.

Para reiniciar una instancia, seleccione una de las siguientes opciones:

linux

  1. Si aún no lo has hecho, conéctate a la instancia .

  2. Para reiniciar la instancia, ejecute el siguiente comando:

    sudo reboot
    

ventanas

  1. Si aún no lo ha hecho, conéctese a la instancia utilizando uno de los siguientes métodos:

  2. Para reiniciar la instancia, ejecute el siguiente comando:

    shutdown /r /t 0
    
  3. Opcional: para monitorear el proceso de apagado y reinicio de la instancia, habilite el menú del Administrador de arranque de Windows .

Restablecer una instancia

Al restablecer una instancia se borran todos los datos de la memoria de la instancia, incluidos los archivos temporales almacenados en los discos RAM. Estos datos se pierden permanentemente y Compute Engine no crea copias de seguridad antes de restablecer la instancia.

Puede restablecer varias instancias simultáneamente o instancias individuales. Para instancias múltiples, use la consola de Google Cloud o, para instancias ubicadas en la misma zona, la CLI de Google Cloud. Para instancias individuales, seleccione cualquiera de las siguientes opciones:

Consola

  1. En la consola de Google Cloud, vaya a la página de instancias de VM .

    Ir a instancias de VM

  2. Seleccione las instancias para restablecer.

  3. Haga clic en Restablecer y luego haga clic en Restablecer para confirmar.

nube de gcloud

Para restablecer una o más instancias en ejecución en una sola zona, usa el comando gcloud compute instances reset :

gcloud compute instances reset INSTANCE_NAMES \
    --zone=ZONE

Reemplace lo siguiente:

  • INSTANCE_NAMES : una lista de nombres de instancias separados por espacios en blanco; por ejemplo, instance-01 instance-02 instance-03 .

  • ZONE : la zona donde se encuentran las instancias.

Ir

import (
	"context"
	"fmt"
	"io"

	compute "cloud.google.com/go/compute/apiv1"
	computepb "cloud.google.com/go/compute/apiv1/computepb"
)

// resetInstance resets a running Google Compute Engine instance (with unencrypted disks).
func resetInstance(w io.Writer, projectID, zone, instanceName string) error {
	// projectID := "your_project_id"
	// zone := "europe-central2-b"
	// instanceName := "your_instance_name"

	ctx := context.Background()
	instancesClient, err := compute.NewInstancesRESTClient(ctx)
	if err != nil {
		return fmt.Errorf("NewInstancesRESTClient: %w", err)
	}
	defer instancesClient.Close()

	req := &computepb.ResetInstanceRequest{
		Project:  projectID,
		Zone:     zone,
		Instance: instanceName,
	}

	op, err := instancesClient.Reset(ctx, req)
	if err != nil {
		return fmt.Errorf("unable to reset instance: %w", err)
	}

	if err = op.Wait(ctx); err != nil {
		return fmt.Errorf("unable to wait for the operation: %w", err)
	}

	fmt.Fprintf(w, "Instance reset\n")

	return nil
}

Java


import com.google.api.gax.longrunning.OperationFuture;
import com.google.cloud.compute.v1.InstancesClient;
import com.google.cloud.compute.v1.Operation;
import com.google.cloud.compute.v1.Operation.Status;
import com.google.cloud.compute.v1.ResetInstanceRequest;
import java.io.IOException;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;

public class ResetInstance {

  public static void main(String[] args)
      throws IOException, ExecutionException, InterruptedException, TimeoutException {
    // TODO(developer): Replace these variables before running the sample.
    /* project: project ID or project number of the Cloud project your instance belongs to.
       zone: name of the zone your instance belongs to.
       instanceName: name of the instance your want to reset.
     */
    String project = "your-project-id";
    String zone = "zone-name";
    String instanceName = "instance-name";

    resetInstance(project, zone, instanceName);
  }

  // Resets a running Google Compute Engine instance (with unencrypted disks).
  public static void resetInstance(String project, String zone, String instanceName)
      throws IOException, ExecutionException, InterruptedException, TimeoutException {
    /* Initialize client that will be used to send requests. This client only needs to be created
       once, and can be reused for multiple requests. After completing all of your requests, call
       the `instancesClient.close()` method on the client to safely
       clean up any remaining background resources. */
    try (InstancesClient instancesClient = InstancesClient.create()) {

      ResetInstanceRequest resetInstanceRequest = ResetInstanceRequest.newBuilder()
          .setProject(project)
          .setZone(zone)
          .setInstance(instanceName)
          .build();

      OperationFuture<Operation, Operation> operation = instancesClient.resetAsync(
          resetInstanceRequest);
      Operation response = operation.get(3, TimeUnit.MINUTES);

      if (response.getStatus() == Status.DONE) {
        System.out.println("Instance reset successfully ! ");
      }
    }
  }

}

Nodo.js

/**
 * TODO(developer): Uncomment and replace these variables before running the sample.
 */
// const projectId = 'YOUR_PROJECT_ID';
// const zone = 'europe-central2-b'
// const instanceName = 'YOUR_INSTANCE_NAME'

const compute = require('@google-cloud/compute');

async function resetInstance() {
  const instancesClient = new compute.InstancesClient();

  const [response] = await instancesClient.reset({
    project: projectId,
    zone,
    instance: instanceName,
  });
  let operation = response.latestResponse;
  const operationsClient = new compute.ZoneOperationsClient();

  // Wait for the operation to complete.
  while (operation.status !== 'DONE') {
    [operation] = await operationsClient.wait({
      operation: operation.name,
      project: projectId,
      zone: operation.zone.split('/').pop(),
    });
  }

  console.log('Instance reset.');
}

resetInstance();

PHP

use Google\Cloud\Compute\V1\Client\InstancesClient;
use Google\Cloud\Compute\V1\ResetInstanceRequest;

/**
 * Reset a running Google Compute Engine instance (with unencrypted disks).
 *
 * @param string $projectId Project ID or project number of the Cloud project your instance belongs to.
 * @param string $zone Name of the zone your instance belongs to.
 * @param string $instanceName Name of the instance you want to reset.
  *
 * @throws \Google\ApiCore\ApiException if the remote call fails.
 * @throws \Google\ApiCore\ValidationException if local error occurs before remote call.
 */
function reset_instance(
    string $projectId,
    string $zone,
    string $instanceName
) {
    // Stop the Compute Engine instance using InstancesClient.
    $instancesClient = new InstancesClient();
    $request = (new ResetInstanceRequest())
        ->setInstance($instanceName)
        ->setProject($projectId)
        ->setZone($zone);
    $operation = $instancesClient->reset($request);

    // Wait for the operation to complete.
    $operation->pollUntilComplete();
    if ($operation->operationSucceeded()) {
        printf('Instance %s reset successfully' . PHP_EOL, $instanceName);
    } else {
        $error = $operation->getError();
        printf('Failed to reset instance: %s' . PHP_EOL, $error?->getMessage());
    }
}

Pitón

from __future__ import annotations

import sys
from typing import Any

from google.api_core.extended_operation import ExtendedOperation
from google.cloud import compute_v1


def wait_for_extended_operation(
    operation: ExtendedOperation, verbose_name: str = "operation", timeout: int = 300
) -> Any:
    """
    Waits for the extended (long-running) operation to complete.

    If the operation is successful, it will return its result.
    If the operation ends with an error, an exception will be raised.
    If there were any warnings during the execution of the operation
    they will be printed to sys.stderr.

    Args:
        operation: a long-running operation you want to wait on.
        verbose_name: (optional) a more verbose name of the operation,
            used only during error and warning reporting.
        timeout: how long (in seconds) to wait for operation to finish.
            If None, wait indefinitely.

    Returns:
        Whatever the operation.result() returns.

    Raises:
        This method will raise the exception received from `operation.exception()`
        or RuntimeError if there is no exception set, but there is an `error_code`
        set for the `operation`.

        In case of an operation taking longer than `timeout` seconds to complete,
        a `concurrent.futures.TimeoutError` will be raised.
    """
    result = operation.result(timeout=timeout)

    if operation.error_code:
        print(
            f"Error during {verbose_name}: [Code: {operation.error_code}]: {operation.error_message}",
            file=sys.stderr,
            flush=True,
        )
        print(f"Operation ID: {operation.name}", file=sys.stderr, flush=True)
        raise operation.exception() or RuntimeError(operation.error_message)

    if operation.warnings:
        print(f"Warnings during {verbose_name}:\n", file=sys.stderr, flush=True)
        for warning in operation.warnings:
            print(f" - {warning.code}: {warning.message}", file=sys.stderr, flush=True)

    return result


def reset_instance(project_id: str, zone: str, instance_name: str) -> None:
    """
    Resets a stopped Google Compute Engine instance (with unencrypted disks).
    Args:
        project_id: project ID or project number of the Cloud project your instance belongs to.
        zone: name of the zone your instance belongs to.
        instance_name: name of the instance your want to reset.
    """
    instance_client = compute_v1.InstancesClient()

    operation = instance_client.reset(
        project=project_id, zone=zone, instance=instance_name
    )

    wait_for_extended_operation(operation, "instance reset")

DESCANSAR

Para restablecer una instancia en ejecución, realice una solicitud POST al método instances.reset :

 POST https://compute.googleapis.com//compute/v1/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/reset

Reemplace lo siguiente:

  • INSTANCE_NAME : el nombre de la instancia.

  • PROJECT_ID : el ID del proyecto donde se encuentra la instancia.

  • ZONE : la zona donde se encuentra la instancia.

¿Qué sigue?