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.
-
Si aún no lo hiciste, configura la autenticación.
La autenticación es el proceso mediante el cual se verifica tu identidad para acceder a los servicios y las APIs de Google Cloud .
Para ejecutar código o muestras desde un entorno de desarrollo local, puedes autenticarte en Compute Engine seleccionando una de las siguientes opciones:
Select the tab for how you plan to use the samples on this page:
When you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication.
-
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.
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
Para obtener más información, consulta Autentica para usar REST en la documentación de autenticación de Google Cloud .
-
Limitaciones
- 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 discos regionales en lugar de discos zonales 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.
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.
Permisos necesarios para esta tarea
Para realizar esta tarea, debes tener los siguientes permisos:
- Todos los permisos necesarios para llamar al método
instanceTemplates.insert
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.
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 createINSTANCE_TEMPLATE_NAME \ --instance-template-region=REGION
Reemplaza REGION
por la región en la que
deseas crear la plantilla de instancias regional.
Crea una plantilla de instancias global con el siguiente comando:
gcloud compute instance-templates createINSTANCE_TEMPLATE_NAME
Si no proporcionas una configuración de plantilla explícita, gcloud compute
usa los siguientes valores predeterminados:
- 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 IPv4 externa efímera
- Tipo de pila:
IPV4_ONLY
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-12 \ --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 propiedades image
y image-project
para cada disco en la marca --create-disk
. Para crear un disco en blanco, no incluyas estas propiedades. De manera opcional, incluye propiedades para las opciones size
y type
del disco. Para especificar discos regionales, usa la propiedad replica-zones
.
gcloud compute instance-templates createINSTANCE_TEMPLATE_NAME \ --machine-type=MACHINE_TYPE \ --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
Sugerencia: Cuando se especifica
el parámetro replica-zones
del disco, los caracteres ^:^
especifican que
el carácter de separación entre valores es dos puntos (:
) en lugar de la
coma esperada (,
).
Reemplaza lo siguiente:
INSTANCE_TEMPLATE_NAME
: es el nombre de la plantilla.MACHINE_TYPE
: Es el tipo de máquina de las VM.DISK_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 tipo de disco predeterminado que se usa depende del valor de la marca--machine-type
.ZONE
yREMOTE_ZONE
: es la zona en la que se creará el disco regional y la zona en la que se replicará.Para los discos zonales, no incluyas la propiedad
replica-zones
.
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:
--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.
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-12 kind: compute#attachedDisk mode: READ_WRITE type: PERSISTENT machineType: c3-standard-4 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
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 CLI de gcloud:
gcloud compute instance-templates create my-instance-template \ --machine-type=c3-standard-4 \ --image-family=debian-12 \ --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.
Para crear una plantilla de instancias regional, realiza una solicitud POST
al
método regionInstanceTemplates.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étodo instanceTemplates.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:
- 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 regionales, define la entrada
initializeParams
con la propiedadreplicaZones
.
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:
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.
Puedes especificar una de las siguientes opciones para la propiedad disks
:
Especifica
initializeParams
para crear discos de arranque para cada instancia. Puedes crear discos con imágenes públicas o personalizadas (o familias de imágenes) con la propiedadsourceImage
, como se muestra en el ejemplo anterior. Para agregar discos en blanco, no especifiques unasourceImage
. También puedes agregar hasta 15 discos secundarios que no sean de arranque con la propiedadinitializeParams
para cada disco adicional.Especifica
source
para conectar un disco de arranque existente. Si conectas un disco de arranque existente, solo se puede crear una instancia a partir de tu plantilla.
De manera opcional, puedes especificar las propiedades diskSizeGb
, diskType
y labels
para initializeParams
y la propiedad diskSizeGb
para source
.
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:
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.
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.
Permisos necesarios para esta tarea
Para realizar esta tarea, debes tener los siguientes permisos:
- Todos los permisos necesarios para llamar al método
instanceTemplates.insert
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 createINSTANCE_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 createINSTANCE_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 createINSTANCE_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:
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.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 VMs 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_NAME attach-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
.
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 de data-disk-a
, pero se establece la eliminación automática para true
y se reemplaza data-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
Para crear una plantilla de instancias regional, usa el método regionInstanceTemplates.insert
o, para crear una plantilla de instancias global, usa el método instanceTemplates.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 campos diskConfigs
.
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:
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 VMs 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:"diskConfigs": [ { "deviceName":
DATA_DISK_NAME , "instantiateFrom": custom-image, "customImage": "projects/PROJECT_ID /global/images/family/IMAGE_FAMILY_NAME " } ]attach-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).
En el ejemplo siguiente, se crea una plantilla de instancias nueva basada en my-source-instance
. En la plantilla de instancias, la imagen de data-disk-a
se reemplaza por projects/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 |
|
Otros discos persistentes de lectura y escritura |
|
Discos de solo lectura |
|
SSD locales |
|
Para cada disco, también puedes anular el atributo auto-delete
a fin de 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.
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.
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:
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.
Permisos necesarios para esta tarea
Para realizar esta tarea, debes tener los siguientes permisos:
- Todos los permisos necesarios para llamar al método
instanceTemplates.insert
Para crear una plantilla de instancias para las VMs de GPU, haz lo siguiente:
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.
Para crear una plantilla de instancias para las VMs de GPU, usa el comando instance-templates create
con la marca --maintenance-policy
establecida como TERMINATE
.
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:
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.
Por ejemplo, supongamos que deseas crear una plantilla de instancias global para VMs de GPU que especifique las siguientes propiedades:
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
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
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.
Si deseas crear una plantilla de instancias para las VMs de GPU, realiza una solicitud POST
al método instanceTemplates.insert
.
En el cuerpo de la solicitud, incluye el campo onHostMaintenance
y configúralo como TERMINATE
.
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:
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.
Por ejemplo, supongamos que deseas crear una plantilla de instancias global para VMs de GPU que especifique las siguientes propiedades:
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
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 de manera automática cuando se inicializa la instancia.
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.
Usa el comando gcloud compute instance-templates create-with-container
:
gcloud compute instance-templates create-with-containerINSTANCE_TEMPLATE_NAME \ --container-image=CONTAINER_IMAGE
Reemplaza lo siguiente:
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á.
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
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 createINSTANCE_TEMPLATE_NAME \ --region=REGION \ --subnet=SUBNET_NAME_OR_URL \ --stack-type=STACK_TYPE \ --instance-template-region=INSTANCE_TEMPLATE_REGION
Reemplaza lo siguiente:
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.STACK_TYPE
: Opcional: Indica si IPv6 está habilitado en la interfaz de red predeterminada. Se pueden usar los siguientes valores:IPV4_ONLY
,IPV4_IPV6
oIPV6_ONLY
(versión preliminar). Si no incluyes esta marca, el valor predeterminado esIPV4_ONLY
.INSTANCE_TEMPLATE_REGION
: es la región en la que deseas crear la plantilla de instancias. Esta región debe ser igual queREGION
.
En el siguiente ejemplo, se crea una plantilla llamada template-qa
que solo crea instancias en la subred subnet-us-qa
.
gcloud compute instance-templates create template-qa \ --region=us-central1 \ --subnet=subnet-us-qa
El resultado es similar a este:
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
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:
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.
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, lo que te permite actualizar las apps y la configuración de tus instancias.
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 las prácticas recomendadas para usar familias de imágenes en Compute Engine.
¿Qué sigue?
- 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.