Puedes detener, iniciar y reiniciar las VMs para admitir el ciclo de vida de tus aplicaciones. Por ejemplo, puede cambiar el número de unidades centrales de procesamiento virtual (vCPUs) asignadas o la cantidad de memoria asignada a una máquina virtual. Debes detener la VM antes de editar la configuración. Cuando termines, debes apagar y volver a encender el dispositivo para aplicar los cambios. En esta página se ofrecen instrucciones para detener, iniciar y reiniciar tus máquinas virtuales en estos procesos.
Antes de empezar
Para usar los comandos de la gdcloud
interfaz de línea de comandos (CLI), asegúrate de haber descargado, instalado y configurado la gdcloud
CLI.
Todos los comandos del dispositivo aislado de GDC usan la CLI gdcloud
o kubectl
y requieren un entorno de sistema operativo (SO).
Obtener la ruta del archivo kubeconfig
Para ejecutar comandos en el servidor de la API Management, asegúrate de tener los siguientes recursos:
Busca el nombre del servidor de la API Management o pregunta a tu administrador de plataforma cuál es.
Inicia sesión y genera el archivo kubeconfig del servidor de la API Management si no tienes uno.
Usa la ruta para sustituir
MANAGEMENT_API_SERVER{"</var>"}}
en estas instrucciones.
Si quieres minimizar el tiempo de inicio de tu VM, sigue las instrucciones de Minimizar el tiempo de inicio de la VM antes de iniciarla.
Solicitar permisos y acceso
Para realizar las tareas que se indican en esta página, debes tener el rol de administrador de máquinas virtuales de proyecto. Sigue los pasos para verificar o pide al administrador de gestión de identidades y accesos de tu proyecto que te asigne el rol Administrador de máquinas virtuales de proyectos (project-vm-admin
) en el espacio de nombres del proyecto en el que reside la VM.
Para realizar operaciones con VMs mediante la consola de GDC o la interfaz de línea de comandos gdcloud, pide al administrador de gestión de identidades y accesos de tu proyecto que te asigne el rol Administrador de VirtualMachine de proyecto y el rol Lector de proyectos (project-viewer
).
Detener una VM
Cuando detienes una máquina virtual (VM), el hipervisor desasigna todos los recursos asociados a la instancia. La VM se apaga.
Detén una VM que esté en estado de ejecución mediante la consola de GDC o kubectl
.
Consola
En el menú de navegación, haz clic en Máquinas virtuales > Instancias.
En la lista de VMs, marca la casilla de la VM en ejecución que quieras detener.
Haz clic en Detener.
En el cuadro de diálogo de confirmación, haz clic en Detener.
gdcloud
Para detener una VM, sigue estos pasos:
gdcloud compute instances stop VM_NAME --project PROJECT
- Sustituye
VM_NAME
por el nombre de la VM. - Sustituye
PROJECT
por el nombre del proyecto de GDC en el que se encuentra la VM.
kubectl
Ejecuta el siguiente comando:
kubectl --kubeconfig MANAGEMENT_API_SERVER \ edit virtualmachines.virtualmachine.gdc.goog VM_NAME \ -n PROJECT
Busca el campo
runningState
en elspec
de la máquina virtual y cambia el valor del campo aStopped
. SirunningState
no está enspec
, añádelo aspec
y asigna el valorStopped
.runningState
spec: runningState: Stopped
Verifica el estado de la VM:
kubectl --kubeconfig MANAGEMENT_API_SERVER \ get virtualmachines.virtualmachine.gdc.goog VM_NAME \ -n PROJECT
Consulta estas definiciones de las variables anteriores.
Variable Definición MANAGEMENT_API_SERVER
La ruta kubeconfig
.VM_NAME
El nombre de la VM. PROJECT
Nombre del proyecto de la VM.
Iniciar una VM
Inicia una VM desde un estado detenido mediante la consola o kubectl
.
Consola
En el menú de navegación, haz clic en Máquinas virtuales > Instancias.
En la lista de VMs, marca la casilla de la VM detenida que quieras iniciar.
Haz clic en Empezar.
En el cuadro de diálogo de confirmación, haz clic en Iniciar.
gdcloud
Para iniciar una VM, sigue estos pasos:
gdcloud compute instances start VM_NAME --project PROJECT
- Sustituye
VM_NAME
por el nombre de la VM. - Sustituye
PROJECT
por el nombre del proyecto de GDC en el que se encuentra la VM.
kubectl
Ejecuta el siguiente comando:
kubectl --kubeconfig MANAGEMENT_API_SERVER \ edit virtualmachines.virtualmachine.gdc.goog VM_NAME \ -n PROJECT
Busca el campo
runningState
en elspec
de la máquina virtual y cambia el valor del campo aRunning
.spec: runningState: Running
Verifica el estado de la VM:
kubectl --kubeconfig MANAGEMENT_API_SERVER \ get virtualmachines.virtualmachine.gdc.goog VM_NAME \ -n PROJECT
Usa estas definiciones para las variables del código de ejemplo.
Variable Definición MANAGEMENT_API_SERVER
La ruta kubeconfig
.NAMESPACE
Espacio de nombres de la VM. VM_NAME
El nombre de la VM. PROJECT
Nombre del proyecto de la VM.
Reiniciar una VM
Cuando reinicias una VM, la máquina vuelve a su estado inicial y se borra el contenido de la memoria.
Reinicia una máquina virtual que esté en estado de ejecución mediante la consola o kubectl
.
Consola
En el menú de navegación, haz clic en Máquinas virtuales > Instancias.
En la lista de VMs, marca la casilla de la VM en ejecución que quieras reiniciar.
Haz clic en Cambiar.
En el cuadro de diálogo de confirmación, haz clic en Borrar.
gdcloud
Para restablecer una VM, sigue estos pasos:
gdcloud compute instances reset VM_NAME --project PROJECT
- Sustituye
VM_NAME
por el nombre de la VM. - Sustituye
PROJECT
por el nombre del proyecto de GDC en el que se encuentra la VM.
kubectl
Obtén los datos del certificado y la clave del cliente, así como el servidor de la API Management. Usa estos valores en los pasos siguientes:
kubectl --kubeconfig MANAGEMENT_API_SERVER config view --raw -o \ jsonpath='{.users[?(@.name =="CLUSTER_NAME-admin")].user.client-certificate-data}' | \ base64 -d > cert kubectl --kubeconfig MANAGEMENT_API_SERVER config view --raw -o \ jsonpath='{.users[?(@.name == "CLUSTER_NAME-admin")].user.client-key-data}' | \ base64 -d > key export APISERVER=`kubectl --kubeconfig MANAGEMENT_API_SERVER \ config view --raw -o \ jsonpath='{.clusters[?(@.name == "CLUSTER_NAME")].cluster.server}'`
Haz una solicitud de API para reiniciar la VM con el comando
wget
y especifica el certificado y la clave del paso anterior:wget --method=PUT -O- --no-check-certificate --certificate cert --private-key key --content-on-error=on $APISERVER/apis/virtualmachineoperations.gdc.goog/v1/namespaces/PROJECT/virtualmachines/VM_NAME/restart
Verifica el estado de la VM:
kubectl --kubeconfig MANAGEMENT_API_SERVER \ get virtualmachines.virtualmachine.gdc.goog VM_NAME -n PROJECT
Usa estas definiciones de las variables en el código de ejemplo.
Variable Definición MANAGEMENT_API_SERVER
La ruta kubeconfig
.VM_NAME
El nombre de la VM. PROJECT
Nombre del proyecto de la VM.