En esta página, se describe cómo crear y administrar plantillas de instancias. Las plantillas de instancias te permiten especificar el tipo de máquina, la imagen de disco de arranque, la red y otras propiedades de VM que se recomienda usar cuando creas instancias de máquinas virtuales (VM).
Puedes usar plantillas de instancias para hacer lo siguiente:
- Crear VMs individuales.
- Crear VMs de backend en un grupo de instancias administrado (MIG).
- Crear reservas para las VMs.
- Crear reservas futuras para las VMs.
Antes de comenzar
- Lee cuándo y por qué crear plantillas de instancias deterministas.
- Lee sobre las plantillas de instancias regionales y globales.
-
Configura la autenticación si aún no lo hiciste.
La autenticación es el proceso mediante el cual se verifica tu identidad para acceder a los servicios y las API de Google Cloud.
Para ejecutar un código o muestras desde un entorno de desarrollo local, puedes autenticarte en Compute Engine de la siguiente manera.
Select the tab for how you plan to use the samples on this page:
Console
When you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication.
gcloud
-
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
- Set a default region and zone.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- La VPC compartida en interfaces que no sean
nic0
para las plantillas de instancias es compatible con gcloud CLI y REST, pero no con la consola de Google Cloud. - No puedes actualizar una plantilla de instancias existente ni modificar una plantilla de instancias después de crearla. Si una plantilla de instancias caduca o si necesitas aplicar cambios en la configuración, debes crear una plantilla de instancias nueva.
- Si deseas especificar una familia de imágenes en una plantilla de instancias, no puedes usar la consola de Google Cloud. En su lugar, puedes usar Google Cloud CLI o REST.
- Si deseas especificar un Persistent Disk regional en una plantilla de instancias, no puedes usar la consola de Google Cloud. En su lugar, puedes usar Google Cloud CLI o REST.
- Puedes usar una plantilla de instancia para crear VMs con un disco de arranque Hyperdisk Balanced que esté en un grupo de almacenamiento, si el grupo de almacenamiento existe en la misma zona en la que se creó la VM. No puedes usar plantillas de instancias globales para crear VMs con discos que no sean de inicio que se encuentran en un grupo de almacenamiento.
En la consola de Google Cloud, ve a la página Plantillas de instancia.
Los pasos restantes aparecen en la consola de Google Cloud.
- Haz clic en
Crear plantilla de instancias . - Selecciona la ubicación de la siguiente manera:
- Si deseas usar la plantilla de instancias entre regiones, elige Global.
- Si deseas reducir la dependencia entre regiones, elige Regional.
- Si eliges regional, selecciona la región en la que deseas crear tu plantilla de instancias.
En los siguientes campos, acepta los valores predeterminados o modifícalos según sea necesario. Los valores predeterminados cambian según la familia de máquinas que selecciones.
- Selecciona un
tipo de máquina . - Para actualizar el tipo o la imagen de disco de arranque, en la sección
Disco de arranque , haz clic en Cambiar. - Para actualizar la configuración de la interfaz de red o de la dirección IP, haz clic en
Opciones avanzadas , luego, en Herramientas de redes y, por último, en la interfaz de red que deseas editar.
- Selecciona un
Opcional: Si eliges una imagen que admite una VM protegida, cambia la configuración de VM protegida de la VM:
- Haz clic en Opciones avanzadas y, luego, en la pestaña Seguridad.
- Si quieres inhabilitar el Inicio seguro, desmarca la casilla de verificación Activar inicio seguro. El Inicio seguro ayuda a proteger las instancias de VM del software malicioso y los rootkits a nivel de inicio y kernel. Para obtener más información, consulta Inicio seguro.
Si quieres inhabilitar el módulo de plataforma segura virtual (vTPM), desmarca la casilla de verificación Activar vTPM. El vTPM habilita el inicio medido, que valida la integridad previa al inicio y la integridad de inicio de la VM. Para obtener más información, consulta Módulo de plataforma segura virtual (vTPM).
Si quieres inhabilitar la supervisión de integridad, desmarca la casilla de verificación Activar supervisión de integridad. La supervisión de integridad te permite supervisar la integridad del arranque de las instancias de VM protegida con Cloud Monitoring. Para obtener más información, consulta Supervisión de integridad.
Opcional: En Opciones avanzadas, haz clic en las pestañas para personalizar aún más tu plantilla. Por ejemplo, puedes agregar hasta 15 discos secundarios que no sean de arranque.
Opcional: Haz clic en REST equivalente para ver el cuerpo de la solicitud REST, que incluye la representación JSON de tu plantilla de instancias.
Haz clic en Crear para crear la plantilla.
- Tipo de máquina: el tipo de máquina, por ejemplo,
n1-standard-1
. - Imagen: la última imagen de Debian
- Disco de arranque: un nuevo disco de arranque estándar con el nombre de la VM
- Red: la red de VPC predeterminada
- Dirección IP: una dirección IP externa efímera
INSTANCE_TEMPLATE_NAME
: es el nombre de la plantilla.REGION
: es la región en la que deseas crear la plantilla de instancias regional.IMAGE_FAMILY
: una familia de imágenes para usar como disco que no sea de arranque.Para obtener más información sobre las familias de imágenes, consulta las prácticas recomendadas para usar familias de imágenes en Compute Engine.
En su lugar, puedes usar la marca
--image=IMAGE
para especificar una versión específica de una imagen.Para los discos en blanco, no especifiques la propiedad
image-family
niimage
.DISK_IMAGE_PROJECT
: Es el proyecto de imagen que contiene la imagen.Para los discos en blanco, no especifiques la propiedad
image-project
. Para obtener más información sobre las imágenes públicas, consulta Imágenes públicas.SIZE_GB_DISK1
ySIZE_GB_DISK2
: es el tamaño de cada disco secundario.DISK_NAME
: Es el nombre del disco que se muestra al SO invitado después de crear la VM (opcional).DISK_TYPE
: es el tipo de disco que se creará (opcional). Si no se especifica, el valor predeterminado espd-standard
opd-balanced
, según el tipo de máquina.ZONE
yREMOTE_ZONE
: es la zona en la que se creará el disco Persistent Disk regional y la zona en la que se replicará.Para los discos zonales, no incluyas la propiedad
replica-zones
.--no-shielded-secure-boot
: Desactiva el inicio seguro.El inicio seguro ayuda a proteger tus instancias de VM de softwares maliciosos y rootkits de nivel de inicio y kernel. Para obtener más información, consulta la documentación sobre Inicio seguro.
--no-shielded-vtpm
: Desactiva el módulo de plataforma segura virtual (vTPM)El vTPM habilita el inicio medido, que valida la integridad previa al inicio y la integridad de inicio de la VM. Para obtener más información, consulta la documentación sobre el Módulo de plataforma de confianza virtual (vTPM).
--no-shielded-integrity-monitoring
: Desactiva la supervisión de integridad.Esta función te permite supervisar la integridad de inicio de las instancias de VM protegida a través de Cloud Monitoring. Para obtener más información, consulta Supervisión de integridad.
- Crea discos adicionales con una imagen pública o personalizada.
- Para agregar un disco en blanco, define la entrada
initializeParams
sin ningún valorsourceImage
. - Para crear discos persistentes regionales, define la entrada
initializeParams
con la propiedadreplicaZones
. PROJECT_ID
: es el ID del proyecto.REGION
: es la región en la que deseas crear la plantilla de instancias regional.INSTANCE_TEMPLATE_NAME
: Es el nombre de la plantilla de instancias.ZONE
: Es la zona en la que se encuentran las VM.MACHINE_TYPE
: Es el tipo de máquina de las VM.-
IMAGE_PROJECT
: Es el proyecto de imagen que contiene la imagen.Para obtener más información sobre imágenes públicas, consulta Imágenes públicas.
-
IMAGE
oIMAGE_FAMILY
: Especifica una de las siguientes opciones:-
IMAGE
: Es una versión específica de la imagenPor ejemplo:
"sourceImage": "projects/debian-cloud/global/images/debian-10-buster-v20200309"
-
IMAGE_FAMILY
: Es una familia de imágenes.Esto crea la VM a partir de la imagen de SO no obsoleta más reciente. Por ejemplo, si especificas
"sourceImage": "projects/debian-cloud/global/images/family/debian-10"
, Compute Engine crea una VM a partir de la última versión de la imagen de SO en la familia de imágenes Debian 10.Para obtener más información sobre las familias de imágenes, consulta las prácticas recomendadas para usar familias de imágenes en Compute Engine.
-
DISK_NAME
: Es el nombre del disco que se muestra al SO invitado después de crear la VM (opcional).PROJECT_NAME
: Es el proyecto asociado con la VM.REMOTE_ZONE
: Es la zona en la que se debe replicar el disco regional.Especifica
initializeParams
para crear discos de arranque persistentes para cada instancia. Puedes agregar hasta 15 discos secundarios que no sean de arranque con la propiedadinitializeParams
para cada disco adicional. Puedes crear discos con imágenes públicas o personalizadas (o familias de imágenes) ensourceImage
, como se muestra en el ejemplo anterior. Para agregar discos en blanco, no especifiques unasourceImage
.Especifica
source
para conectar un disco de arranque persistente existente. Si conectas un disco de arranque existente, solo se puede crear una instancia a partir de tu plantilla.enableSecureBoot
: Activa o desactiva el inicio seguroEl inicio seguro ayuda a proteger tus instancias de VM de softwares maliciosos y rootkits de nivel de inicio y kernel. Para obtener más información, consulta la documentación sobre Inicio seguro.
enableVtpm
: Activa o desactiva el módulo de plataforma segura virtual (vTPM).El vTPM habilita el inicio medido, que valida la integridad previa al inicio y la integridad de inicio de la VM. Para obtener más información, consulta la documentación sobre el Módulo de plataforma de confianza virtual (vTPM).
enableIntegrityMonitoring
: Activa o desactiva la supervisión de integridadLa supervisión de integridad te permite supervisar y verificar la integridad de inicio del entorno de ejecución correspondiente a las instancias de VM protegida a través de informes de Cloud Monitoring. Para obtener más información, consulta Supervisión de integridad.
INSTANCE_TEMPLATE_NAME
es el nombre de la plantilla que se creará.SOURCE_INSTANCE
es el nombre de la instancia que se usará como modelo para la plantilla nueva.SOURCE_INSTANCE_ZONE
es la zona que contiene la instancia de origen.REGION
es la región en la que deseas crear la plantilla de instancias regional.SOURCE_DISK
es el nombre de un disco de instancia de origen que quieres anular dentro de la plantilla.INSTANTIATE_OPTIONS
especifica si se debe incluir el disco y qué imagen usar. Los valores válidos dependen del tipo de disco:source-image
osource-image-family
(válidos solo para el inicio y otros discos persistentes de lectura y escritura). Especifica esta opción si deseas usar la misma imagen de origen o familia de imágenes de origen que se usó para crear el disco en la instancia de VM de origen.custom-image
(válido solo para inicio y otros discos persistentes de lectura y escritura). Si deseas conservar las aplicaciones y la configuración de las VM de origen en la plantilla de instancias, puedes crear una imagen personalizada y especificarla cuando crees la plantilla. Si se especifica, proporciona la ruta o URL de la imagen personalizada, como se muestra en el ejemplo siguiente. Como alternativa, también puedes especificar una familia de imágenes con el siguiente formato:--configure-disk=device-name=DATA_DISK_NAME,instantiate-from=custom-image,
custom-image=projects/PROJECT_ID/global/images/family/IMAGE_FAMILY_NAMEattach-read-only
(válido solo para discos de solo lectura).blank
(válido solo para los discos persistentes que no son de arranque y los SSD locales). Si se especifica, entonces, cuando se usa la plantilla para crear una instancia nueva, el disco se crea sin formato. Debes formatear y activar el disco en una secuencia de comandos de inicio antes de poder usarlo en una configuración escalable.do-not-include
(válido solo para los discos persistentes que no son de arranque y los discos de solo lectura).
AUTO_DELETE
especifica si el disco se borra automáticamente cuando se borra la instancia. Los valores válidos sonfalse
,no
,true
yyes
.PROJECT_ID
: es el ID del proyecto.INSTANCE_TEMPLATE_NAME
: Es el nombre de la plantilla nueva.SOURCE_INSTANCE_ZONE
: Es la zona de la instancia de origen.SOURCE_INSTANCE
: Es el nombre de la instancia de origen que se usará como modelo para esta plantilla de instancias.SOURCE_DISK
: Es el nombre de un disco de instancia de origen que quieres anular dentro de la plantilla.INSTANTIATE_OPTIONS
: Especifica si se debe incluir el disco y qué imagen usar.Los valores válidos dependen del tipo de disco:
source-image
osource-image-family
(válidos solo para el inicio y otros discos persistentes de lectura y escritura).custom-image
(válido solo para inicio y otros discos persistentes de lectura y escritura). Si deseas conservar las aplicaciones y la configuración de las VM de origen en la plantilla de instancias, puedes crear una imagen personalizada y especificarla cuando crees la plantilla. Si se especifica, proporciona la ruta o URL de la imagen personalizada, como se muestra en el ejemplo siguiente. Como alternativa, también puedes especificar una familia de imágenes con el siguiente formato:--configure-disk=device-name=DATA_DISK_NAME,instantiate-from=custom-image,
custom-image=projects/PROJECT_ID/global/images/family/IMAGE_FAMILY_NAMEattach-read-only
(válido solo para discos de solo lectura).blank
(válido solo para los discos persistentes que no son de arranque y los SSD locales). Si se especifica, entonces, cuando se usa la plantilla para crear una instancia nueva, el disco se crea sin formato. Debes formatear y activar el disco en una secuencia de comandos de inicio antes de poder usarlo en una configuración escalable.do-not-include
(válido solo para los discos persistentes que no son de arranque y los discos de solo lectura).
- [Predeterminado] Usa la misma imagen fuente o familia de imágenes que se usó para crear el disco de arranque en la instancia de origen.
- Usa la URL de cualquier imagen (personalizada o pública) como se describe en el ejemplo anterior o especifica una familia de imágenes con el siguiente formato:
- [Predeterminado] Usa la misma imagen de origen o familia de imágenes de origen que se usó para crear el disco en la instancia de origen. Nota: Si el disco de la instancia de origen no tiene una propiedad de imagen de origen o familia de imágenes de origen, se incluye en la plantilla como un disco en blanco.
- Usa la URL de cualquier imagen (personalizada o pública) como se describe en el ejemplo anterior o especifica una familia de imágenes con el siguiente formato:
projects/exampleproject/global/images/family/IMAGE_FAMILY_NAME
- De lo contrario, usa un disco en blanco en la plantilla. Cuando la plantilla se usa para crear una instancia nueva, este disco se crea sin formato. Debes formatear y activar el disco en una secuencia de comandos de inicio antes de poder usarlo en una configuración escalable.
- No incluyas el disco.
- [Predeterminado] Incluye el disco en modo de solo lectura.
- No incluyas el disco.
- [Predeterminado] Incluye un SSD local en blanco. Cuando la plantilla se usa para crear una instancia nueva, este disco se crea sin formato. Debes formatear y activar el disco en una secuencia de comandos de inicio antes de usarlo en una configuración escalable.
Ve a la página Plantillas de instancias.
Haz clic en la plantilla de instancias que deseas copiar y actualizar.
Haz clic en Crear una similar.
Actualiza la configuración en la plantilla nueva.
Haz clic en Crear.
Un tipo de máquina que admita el tipo de GPU que deseas. Si deseas crear una plantilla de instancias regional, el tipo de GPU que especifiques en la plantilla debe estar disponible en al menos una zona de la región.
Una política de mantenimiento que detiene las VMs durante los eventos de mantenimiento del host.
En la consola de Google Cloud, ve a la página Plantillas de instancia.
Haz clic en Crear plantilla de instancias.
En el campo Nombre, ingresa un nombre para la plantilla de instancias.
En la sección Ubicación, selecciona una de las siguientes opciones:
Para crear una plantilla de instancias global, selecciona Global (predeterminado).
Para crear una plantilla de instancias regional, selecciona Regional y, luego, la región en la que deseas crear la plantilla de instancias.
En la sección Configuración de la máquina, haz lo siguiente:
Haz clic en la pestaña GPU.
En el menú Tipo de GPU, selecciona el tipo de GPU.
En el menú Cantidad de GPU, selecciona la cantidad.
Opcional: Si tu modelo de GPU es compatible con estaciones de trabajo virtuales (vWS) NVIDIA RTX para cargas de trabajo de gráficos y planeas ejecutar cargas de trabajo de alto contenido gráfico, selecciona Habilitar estación de trabajo virtual (NVIDIA GRID).
En la sección Tipo de máquina, selecciona un tipo de máquina.
Opcional: Para cambiar el valor o la imagen de disco de arranque predeterminados, en la sección Disco de arranque, haz clic en Cambiar. Luego, sigue las instrucciones para cambiar el disco de arranque.
Haz clic en Crear.
INSTANCE_TEMPLATE_NAME
: el nombre de la plantilla de instancias.IMAGE_PROJECT
: el proyecto de imagen que contiene la imagen; por ejemplo,debian-cloud
. Para obtener más información sobre los proyectos de imágenes compatibles, consulta Imágenes públicas.IMAGE_FAMILY
oIMAGE
: especifica una de las siguientes opciones:IMAGE_FAMILY
: Es una familia de imágenes. Esto especifica la imagen de SO no obsoleta más reciente. Por ejemplo, si especificasdebian-10
, se usa la versión más reciente de la familia de imágenes de Debian 10. Para obtener más información sobre el uso de las familias de imágenes, consulta Prácticas recomendadas para las familias de imágenes.IMAGE
: una versión específica de la imagen de SO; por ejemplo,debian-10-buster-v20200309
. Si eliges especificar una versión específica de la imagen del SO, debes reemplazar la marca--image-family
por la marca--image
.
MACHINE_TYPE
: el tipo de máquina de las VMs. Si especificas un tipo de máquina N1, incluye la marca--accelerator
para especificar la cantidad y el tipo de GPU que conectarás a las VMs.Un tipo predefinido de máquina N1 con 2 CPUs virtuales
Una GPU NVIDIA T4 para conectar a las VMs.
Debian como el proyecto de imagen
Debian 10 como la familia de imágenes
PROJECT_ID
: Es el ID del proyecto en el que deseas crear la plantilla de instancias.INSTANCE_TEMPLATE_NAME
: el nombre de la plantilla de instancias.IMAGE_PROJECT
: el proyecto de imagen que contiene la imagen; por ejemplo,debian-cloud
. Para obtener más información sobre los proyectos de imágenes compatibles, consulta Imágenes públicas.IMAGE
oIMAGE_FAMILY
: especifica una de las siguientes opciones:IMAGE
: una versión específica de la imagen de SO; por ejemplo,debian-10-buster-v20200309
.IMAGE_FAMILY
: Es una familia de imágenes. Esto especifica la imagen de SO no obsoleta más reciente. Por ejemplo, si especificasfamily/debian-10
, se usa la versión más reciente de la familia de imágenes de Debian 10. Para obtener más información sobre el uso de las familias de imágenes, consulta Prácticas recomendadas para las familias de imágenes.
MACHINE_TYPE
: el tipo de máquina de las VMs. Si especificas un tipo de máquina N1, incluye el campoguestAccelerators
para especificar la cantidad y el tipo de GPU que conectarás a las VMs.Un tipo predefinido de máquina N1 con 2 CPUs virtuales
Una GPU NVIDIA T4 para conectar a las VMs.
Debian como el proyecto de imagen
Debian 10 como la familia de imágenes
Ve a la página Plantillas de instancias.
Haz clic en Crear plantilla de instancias.
En la sección Contenedor, haz clic en Implementar contenedor.
En el cuadro de diálogo Configurar contenedor, especifica la Imagen de contenedor que deseas usar.
- Puedes especificar una imagen de Container Registry o Artifact Registry.
Por ejemplo:
gcr.io/cloud-marketplace/google/nginx1:TAG
, en la que TAG es la etiqueta definida para una versión específica de la imagen de contenedor NGINX disponible en Google Cloud Marketplace.- Con
us-docker.pkg.dev/google-samples/containers/gke/hello-app:1.0
, se selecciona una imagen de muestra dehello-app
almacenada en Artifact Registry.
- Si usas una imagen de contenedor de Docker Hub, especifica siempre el nombre completo de la imagen de Docker. Por ejemplo, especifica el siguiente nombre de imagen para implementar una imagen de contenedor de Apache:
docker.io/httpd:2.4
.
- Puedes especificar una imagen de Container Registry o Artifact Registry.
Por ejemplo:
De manera opcional, haz clic en Opciones avanzadas de contenedor. Si quieres obtener más información, consulta Configura opciones para ejecutar tu contenedor.
Haz clic en Crear.
INSTANCE_TEMPLATE_NAME
: Es el nombre de la plantilla que se creará.CONTAINER_IMAGE
: Es el nombre completo de la imagen de contenedor que se usará.INSTANCE_TEMPLATE_NAME
: El nombre de la plantilla de instancias.REGION
: Es la región de la subred.SUBNET_NAME_OR_URL
: Es el nombre de la subred o su URL.INSTANCE_TEMPLATE_REGION
: es la región en la que deseas crear la plantilla de instancias. Debe ser igual que REGION.Imágenes personalizadas. Como los MIG están diseñados para agregar y quitar instancias con frecuencia, es útil crear una imagen personalizada y especificarla en la plantilla de instancias. Puedes preparar la imagen con las aplicaciones y la configuración que necesitan tus VM para que no tengas que configurar de forma manual esos elementos en las VM individuales del MIG.
Imágenes públicas. Puedes crear una plantilla de instancias que use una imagen pública y una secuencia de comandos de inicio para preparar la instancia después de que comience a ejecutarse.
- Crear una instancia de VM a partir de una plantilla de instancias.
- Crea un grupo de instancias administrado zonal (MIG).
- Crea un MIG regional.
- Actualiza las VMs en un MIG existente para usar la configuración de una plantilla nueva.
- Crea una reserva para las VMs.
Terraform
Para usar las muestras de Terraform de esta página en un entorno de desarrollo local, instala e inicializa gcloud CLI y, luego, configura las credenciales predeterminadas de la aplicación con tus credenciales de usuario.
Para obtener más información, consulta Set up authentication for a local development environment.
Go
Para usar las muestras de Go de esta página en un entorno de desarrollo local, instala e inicializa gcloud CLI y, luego, configura las credenciales predeterminadas de la aplicación con tus credenciales de usuario.
Para obtener más información, consulta Set up authentication for a local development environment.
Java
Para usar las muestras de Java de esta página en un entorno de desarrollo local, instala e inicializa gcloud CLI y, luego, configura las credenciales predeterminadas de la aplicación con tus credenciales de usuario.
Para obtener más información, consulta Set up authentication for a local development environment.
Node.js
Para usar las muestras de Node.js de esta página en un entorno de desarrollo local, instala e inicializa gcloud CLI y, luego, configura las credenciales predeterminadas de la aplicación con tus credenciales de usuario.
Para obtener más información, consulta Set up authentication for a local development environment.
Python
Para usar las muestras de Python de esta página en un entorno de desarrollo local, instala e inicializa gcloud CLI y, luego, configura las credenciales predeterminadas de la aplicación con tus credenciales de usuario.
Para obtener más información, consulta Set up authentication for a local development environment.
REST
Para usar las muestras de la API de REST en esta página en un entorno de desarrollo local, debes usar las credenciales que proporcionas a la CLI de gcloud.
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
Si deseas obtener más información, consulta Autentica para usar REST en la documentación de autenticación de Google Cloud.
Limitaciones
Crea una plantilla de instancias
La mayoría de las propiedades de VM que puedes especificar en una solicitud para crear una instancia de VM individual también se pueden especificar en una plantilla de instancias, incluidos los metadatos de VM, las secuencias de comandos de inicio, los discos persistentes y las cuentas de servicio. Debes especificar el tipo de máquina, el disco de arranque y la red.
Crea una plantilla de instancias regional o global a través de la consola de Google Cloud, Google Cloud CLI o la API. Para crear una plantilla de instancias global, también puedes usar Terraform o las bibliotecas cliente de Cloud.
Console
gcloud
Para crear una plantilla de instancias regional o global, usa el comando
instance-templates create
. Para una plantilla de instancias regional, debes usar la marca--instance-template-region
para configurar la región de la plantilla.Crea una plantilla de instancias regional con el siguiente comando:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --instance-template-region=REGION
Crea una plantilla de instancias global con el siguiente comando:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME
Si no proporcionas una configuración de plantilla explícita,
gcloud compute
usa los siguientes valores predeterminados:También puedes proporcionar de manera explícita estos ajustes de configuración. Por ejemplo:
gcloud compute instance-templates create example-template-custom \ --machine-type=e2-standard-4 \ --image-family=debian-10 \ --image-project=debian-cloud \ --boot-disk-size=250GB
Puedes agregar hasta 15 discos secundarios que no sean de arranque. Especifica la marca
--create-disk
para cada disco secundario que crees. Para crear discos secundarios a partir de una imagen pública o personalizada, especifica las propiedadesimage
yimage-project
para cada disco en la marca--create-disk
. Para crear un disco en blanco, no incluyas estas propiedades. Tienes la opción de incluir propiedades para las opcionessize
ytype
del disco. Para especificar discos persistentes regionales, usa la propiedadreplica-zones
.gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --create-disk= \ image-family=DISK_IMAGE_FAMILY, \ image-project=DISK_IMAGE_PROJECT, \ size=SIZE_GB_DISK1 \ --create-disk= \ device-name=DISK_NAME,type=DISK_TYPE, \ size=SIZE_GB_DISK2 \ replica-zones=^:^ZONE:REMOTE_ZONE, \ boot=false
Reemplaza lo siguiente:
Si eliges una imagen que admite una VM protegida, puedes cambiar de manera opcional la configuración de VM protegida de la instancia con una de las siguientes marcas:
Para obtener una lista de todos los subcomandos y las marcas disponibles, consulta la referencia de
instance-templates
.Una plantilla con la configuración predeterminada podría tener el aspecto siguiente:
gcloud compute instance-templates describe example-template
creationTimestamp: '2019-09-10T16:18:32.042-07:00' description: '' id: '6057583701980539406' kind: compute#instanceTemplate name: example-template properties: canIpForward: false disks: - autoDelete: true boot: true initializeParams: sourceImage: https://compute.googleapis.com/compute/v1/projects/debian-cloud/global/images/family/debian-10 kind: compute#attachedDisk mode: READ_WRITE type: PERSISTENT machineType: e2-standard-2 networkInterfaces: - accessConfigs: - kind: compute#accessConfig name: external-nat type: ONE_TO_ONE_NAT network: https://compute.googleapis.com/compute/v1/projects/myproject/global/networks/default scheduling: automaticRestart: true onHostMaintenance: MIGRATE serviceAccounts: - email: default scopes: - https://www.googleapis.com/auth/devstorage.read_only selfLink: https://compute.googleapis.com/compute/v1/projects/myproject/global/instanceTemplates/example-template
Terraform
Para crear una plantilla de instancias, puedes usar el recurso
google_compute_instance_template
.El siguiente ejemplo de Terraform es similar al siguiente comando de la gcloud CLI:
gcloud compute instance-templates create my-instance-template \ --machine-type=e2-standard-4 \ --image-family=debian-9 \ --image-project=debian-cloud \ --boot-disk-size=250GB
Si deseas obtener más información para aplicar o quitar una configuración de Terraform, consulta los comandos básicos de Terraform.
Go
Java
Node.js
Python
REST
Para crear una plantilla de instancias regional, realiza una solicitud
POST
al métodoregionInstanceTemplates.insert
de la siguiente manera:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/instanceTemplates
Para crear una plantilla de instancias global, realiza una solicitud
POST
al métodoinstanceTemplates.insert
:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/instanceTemplates
Puedes agregar hasta 15 discos secundarios que no sean de arranque con la propiedad
disks
, con un campo para cada disco adicional. Para cada disco adicional, puedes hacer lo siguiente:En el cuerpo de la solicitud, proporciona las propiedades de la plantilla:
{ "name": "INSTANCE_TEMPLATE_NAME", "properties": { "machineType": "MACHINE_TYPE", "networkInterfaces": [ { "network": "global/networks/default", "accessConfigs": [ { "name": "external-IP", "type": "ONE_TO_ONE_NAT" } ] } ], "disks": [ { "type": "PERSISTENT", "boot": true, "mode": "READ_WRITE", "initializeParams": { "sourceImage": "projects/IMAGE_PROJECT/global/images/IMAGE" } }, { "type": "PERSISTENT", "boot": false, "deviceName": "DISK_NAME", "initializeParams": { "replicaZones": [ "projects/PROJECT_NAME/zones/ZONE", "projects/PROJECT_NAME/zones/REMOTE_ZONE" ] } } ] } }
Reemplaza lo siguiente:
Puedes especificar una de las siguientes opciones para la propiedad
disks
:De manera opcional, puedes especificar las propiedades
diskSizeGb
,diskType
ylabels
parainitializeParams
y la propiedaddiskSizeGb
parasource
.Si eliges una imagen compatible con una VM protegida, puedes cambiar de manera opcional la configuración de VM protegida de la VM con los siguientes elementos del cuerpo de solicitud booleana:
Para obtener más información sobre los parámetros de solicitud, consulta el método
instanceTemplates.insert
.Crea una plantilla de instancias basada en una instancia existente
Puedes usar REST o gcloud CLI para guardar la configuración de una instancia de VM existente como una plantilla de instancias. Puedes anular la forma en que se definen los discos de origen en la plantilla.
Si necesitas anular otras propiedades, primero crea una plantilla de instancias basada en una instancia existente y, luego, crea una plantilla similar con anulaciones adicionales.
gcloud
Usa el comando
gcloud compute instance-templates create
con las marcas--source-instance
y--source-instance-zone
. Si deseas crear una plantilla de instancias regional, también debes usar la marca--instance-template-region
para especificar la región de la plantilla de instancias.Para crear una plantilla de instancias regional, usa el siguiente comando:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --source-instance=SOURCE_INSTANCE \ --source-instance-zone=SOURCE_INSTANCE_ZONE \ --instance-template-region=REGION
Para crear una plantilla de instancias global, usa el siguiente comando:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --source-instance=SOURCE_INSTANCE \ --source-instance-zone=SOURCE_INSTANCE_ZONE
Para anular cómo se definen los discos de la instancia de origen, agrega una o más marcas
--configure-disk
de la siguiente forma:En el siguiente ejemplo, se crea una plantilla de instancias global a partir de una instancia existente y se anula el disco de la instancia de origen con las especificaciones que proporcionas.
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --source-instance=SOURCE_INSTANCE \ --source-instance-zone=SOURCE_INSTANCE_ZONE \ --configure-disk= \ device-name=SOURCE_DISK, \ instantiate-from=INSTANTIATE_OPTIONS, \ auto-delete=AUTO_DELETE
Reemplaza lo siguiente:
Por ejemplo, con el comando siguiente, se crea una plantilla de instancias basada en
my-source-instance
, con la opción de usar la imagen original dedata-disk-a
, pero se establece la eliminación automática paratrue
y se reemplazadata-disk-b
por una imagen personalizada.gcloud compute instance-templates create my-instance-template \ --source-instance=my-source-instance \ --configure-disk=device-name=data-disk-a,instantiate-from=source-image, \ auto-delete=true --configure-disk=device-name=data-disk-b,instantiate-from=custom-image, \ custom-image=projects/cps-cloud/global/images/cos-89-16108-403-15
Go
Java
Node.js
Python
REST
Para crear una plantilla de instancias regional, usa el método
regionInstanceTemplates.insert
o, para crear una plantilla de instancias global, usa el métodoinstanceTemplates.insert
.En tu solicitud, debes especificar el campo
sourceInstance
. Para anular cómo se definen los discos de la instancia de origen, agrega uno o más camposdiskConfigs
.Por ejemplo, realiza la siguiente llamada para crear una plantilla de instancias global a partir de una instancia existente.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/instanceTemplates { "name": "INSTANCE_TEMPLATE_NAME", "sourceInstance": "zones/SOURCE_INSTANCE_ZONE/instances/SOURCE_INSTANCE", "sourceInstanceParams": { "diskConfigs": [ { "deviceName": "SOURCE_DISK", "instantiateFrom": "INSTANTIATE_OPTIONS", "autoDelete": false } ] } }
Reemplaza lo siguiente:
En el ejemplo siguiente, se crea una plantilla de instancias nueva basada en
my-source-instance
. En la plantilla de instancias, la imagen dedata-disk-a
se reemplaza porprojects/cos-cloud/global/images/cos-89-16108-403-15
.POST https://compute.googleapis.com/compute/v1/projects/my_project/global/instanceTemplates { "name": "my-instance-template", "sourceInstance": "zones/us-central1-a/instances/my-source-instance", "sourceInstanceParams": { "diskConfigs": [ { "deviceName": "data-disk-a", "instantiateFrom": "custom-image", "customImage": "projects/cos-cloud/global/images/cos-89-16108-403-15" } ] } }
En la siguiente tabla, se muestra cómo se definen las opciones para anular discos en la plantilla.
Tipo de disco Opciones Disco de arranque projects/exampleproject/global/images/family/IMAGE_FAMILY_NAME
Otros discos persistentes de lectura y escritura Discos de solo lectura SSD locales Para cada disco, también puedes anular el atributo
auto-delete
para especificar si el disco se debe borrar cuando se borra su instancia asociada.De forma predeterminada, si no se especifican opciones de anulación, la configuración del disco en la plantilla coincide con la instancia de origen.
Crea una plantilla de instancias basada en una plantilla existente
No puedes actualizar una plantilla de instancias existente. Sin embargo, si una plantilla de instancias está desactualizada o si necesitas hacer cambios, puedes crear otra con propiedades similares en la consola.
Crea una plantilla de instancias para las VMs de GPU
Cuando creas una plantilla de instancias, puedes configurarla para crear VMs que tengan GPUs conectadas. Para ello, especifica lo siguiente:
Console
Para crear una plantilla de instancias para las VMs de GPU, haz lo siguiente:
gcloud
Para crear una plantilla de instancias para las VMs de GPU, usa el comando
instance-templates create
con la marca--maintenance-policy
establecida comoTERMINATE
.Por ejemplo, para crear una plantilla de instancias global para las VMs de GPU, usa el siguiente comando:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --image-project=IMAGE_PROJECT \ --image-family=IMAGE_FAMILY \ --machine-type=MACHINE_TYPE \ --maintenance-policy=TERMINATE
Reemplaza lo siguiente:
Por ejemplo, supongamos que deseas crear una plantilla de instancias global para VMs de GPU que especifique las siguientes propiedades:
Para crear la plantilla de instancias de ejemplo, usa el siguiente comando:
gcloud compute instance-templates create instance-template-gpu \ --accelerator=count=1,type=nvidia-tesla-t4 \ --machine-type=n1-standard-2 \ --image-family=debian-10 \ --image-project=debian-cloud \ --maintenance-policy=TERMINATE
Terraform
Para crear una plantilla de instancias para las VMs de GPU, usa el recurso
google_compute_region_instance_template
.Por ejemplo, para crear una plantilla de instancias global, que especifique un tipo predefinido de máquina N1 con 2 CPU virtuales y una GPU NVIDIA T4 conectada, usa el siguiente recurso:
Si deseas obtener más información para aplicar o quitar una configuración de Terraform, consulta los comandos básicos de Terraform.
REST
Si deseas crear una plantilla de instancias para las VMs de GPU, realiza una solicitud
POST
al métodoinstanceTemplates.insert
. En el cuerpo de la solicitud, incluye el campoonHostMaintenance
y configúralo comoTERMINATE
.Por ejemplo, para crear una plantilla de instancias global para las VMs de GPU, realiza una solicitud
POST
de la siguiente manera:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/instanceTemplates { "name": "INSTANCE_TEMPLATE_NAME", "properties": { "disks": [ { "type": "PERSISTENT", "boot": true, "mode": "READ_WRITE", "initializeParams": { "sourceImage": "projects/IMAGE_PROJECT/global/images/IMAGE" } } ], "machineType": "MACHINE_TYPE", "networkInterfaces": [ { "accessConfigs": [ { "name": "external-IP", "type": "ONE_TO_ONE_NAT" } ], "network": "global/networks/default" } ], "scheduling": { "onHostMaintenance": "TERMINATE" } } }
Reemplaza lo siguiente:
Por ejemplo, supongamos que deseas crear una plantilla de instancias global para VMs de GPU que especifique las siguientes propiedades:
Para crear la plantilla de instancias de ejemplo, realiza una solicitud
POST
de la siguiente manera:POST https://compute.googleapis.com/compute/v1/projects/example-project/global/instanceTemplates { "name": "instance-template-gpu", "properties": { "disks": [ { "type": "PERSISTENT", "boot": true, "mode": "READ_WRITE", "initializeParams": { "sourceImage": "projects/debian-cloud/global/images/family/debian-10" } } ], "guestAccelerators": [ { "acceleratorType": "nvidia-tesla-t4", "acceleratorCount": 1 } ], "machineType": "n1-standard-2", "networkInterfaces": [ { "accessConfigs": [ { "name": "external-IP", "type": "ONE_TO_ONE_NAT" } ], "network": "global/networks/default" } ], "scheduling": { "onHostMaintenance": "TERMINATE" } } }
Para obtener más opciones de configuración cuando crees una plantilla de instancias, consulta Crea una plantilla de instancias en este documento.
Crea una plantilla de instancias con una imagen de contenedor
Puedes especificar una imagen de contenedor en una plantilla de instancias. De forma predeterminada, Compute Engine también incluye en la plantilla una imagen de Container-Optimized OS con Docker instalado. Si usas la plantilla para crear una instancia nueva, el contenedor se inicia automáticamente cuando se inicializa la instancia.
Console
gcloud
Usa el comando
gcloud compute instance-templates create-with-container
:gcloud compute instance-templates create-with-container INSTANCE_TEMPLATE_NAME \ --container-image=CONTAINER_IMAGE
Reemplaza lo siguiente:
Por ejemplo, con el siguiente comando, se crea una plantilla de instancias nueva llamada
nginx-vm
. Una instancia de VM creada a partir de esta plantilla inicia y ejecuta la imagen de contenedor,gcr.io/cloud-marketplace/google/nginx1:TAG
, cuando se inicia la VM.gcloud compute instance-templates create-with-container nginx-vm \ --container-image=gcr.io/cloud-marketplace/google/nginx1:TAG
Reemplaza
TAG
por la etiqueta definida para una versión específica de la imagen de contenedor NGINX disponible en Google Cloud Marketplace.También puedes configurar las opciones para ejecutar tu contenedor.
Crea una plantilla de instancias que especifique una subred
gcloud
Para crear una plantilla de instancias regional o global, usa el comando
instance-templates create
. Usa la marca--subnet
para colocar las instancias que se crean a partir de la plantilla en la subred que elijas. La marca--subnet
requiere la marca--region
.Si deseas crear una plantilla de instancias regional, debes usar la marca
--instance-template-region
para establecer la región de la plantilla. Asegúrate de usar una subred de la misma región en la que deseas crear la plantilla de instancias regional.gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --region=REGION \ --subnet=SUBNET_NAME_OR_URL \ --instance-template-region=INSTANCE_TEMPLATE_REGION
Reemplaza lo siguiente:
En el siguiente ejemplo, se crea una plantilla llamada
template-qa
que solo crea instancias en la subredsubnet-us-qa
.gcloud compute instance-templates create template-qa \ --region=us-central1 \ --subnet=subnet-us-qa Created [https://compute.googleapis.com/compute/latest/projects/PROJECT_ID/global/instanceTemplates/template-qa]. NAME MACHINE_TYPE PREEMPTIBLE CREATION_TIMESTAMP template-qa e2-standard-2 2019-12-23T20:34:00.791-07:00
Go
Java
Node.js
Python
Si usas esta plantilla en la creación de instancias para un MIG (con o sin ajuste de escala automático), la instancia se crea de forma automática en la región y subred especificadas. Esto te permite controlar la subred de las instancias nuevas creadas para el balanceo de cargas.
Usa imágenes personalizadas o públicas en tus plantillas de instancias
Puedes usar una imagen personalizada o pública para las plantillas de instancias:
Las imágenes personalizadas son más deterministas y se inician con más velocidad que las VM con secuencias de comandos de inicio. Sin embargo, las secuencias de comandos de inicio son más flexibles y te permiten actualizar las apps y la configuración de tus instancias con más facilidad.
Si administras imágenes con familias de imágenes, puedes especificar el nombre de tu familia de imágenes públicas o personalizadas en la plantilla de instancias. Para obtener más información sobre las familias de imágenes, consulta Prácticas recomendadas para usar familias de imágenes en Compute Engine.
¿Qué sigue?
Salvo que se indique lo contrario, el contenido de esta página está sujeto a la licencia Atribución 4.0 de Creative Commons, y los ejemplos de código están sujetos a la licencia Apache 2.0. Para obtener más información, consulta las políticas del sitio de Google Developers. Java es una marca registrada de Oracle o sus afiliados.
Última actualización: 2024-11-25 (UTC)
-