本页面介绍如何创建和管理实例模板。通过实例模板,您可以指定在创建虚拟机 (VM) 实例时要使用的机器类型、启动磁盘映像、网络和其他虚拟机属性。
您可以使用实例模板执行以下操作:
- 创建单个虚拟机。
- 创建托管式实例组 (MIG) 中的虚拟机。
- 创建虚拟机预留。
准备工作
- 了解何时以及为何要创建确定性实例模板。
- 了解区域和全球实例模板。
-
如果您尚未设置身份验证,请进行设置。身份验证是通过其进行身份验证以访问 Google Cloud 服务和 API 的过程。如需从本地开发环境运行代码或示例,您可以通过选择以下选项之一向 Compute Engine 进行身份验证:
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
-
After installing the Google Cloud CLI, initialize it by running the following command:
gcloud init
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
- Set a default region and zone.
-
Install the Google Cloud CLI.
-
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
-
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.
If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity.
-
Install the Google Cloud CLI.
-
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
-
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.
If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity.
-
Install the Google Cloud CLI.
-
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
-
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.
If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity.
-
Install the Google Cloud CLI.
-
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
-
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.
If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity.
-
Install the Google Cloud CLI.
-
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
-
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.
If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity.
- gcloud CLI 和 REST 支持实例模板中位于
nic0
以外接口的共享 VPC,但Google Cloud 控制台不支持。 - 您无法更新现有实例模板,也无法在创建实例模板后对其进行更改。如果实例模板过期,或者您需要更改配置,请创建一个新的实例模板。
- 如果您要在实例模板中指定映像系列,则无法使用 Google Cloud 控制台。您可以改用 Google Cloud CLI 或 REST。
- 如果要在实例模板中指定区域级磁盘(而不是可用区级磁盘),则无法使用 Google Cloud 控制台。您可以改用 Google Cloud CLI 或 REST。
- 您可以使用实例模板创建位于存储池中的 Hyperdisk Balanced 启动磁盘的虚拟机,前提是该存储池位于创建虚拟机的可用区中。您无法使用全球实例模板创建存储在存储池中的非启动磁盘的虚拟机。
在 Google Cloud 控制台中,转到实例模板页面。
其余步骤会显示在 Google Cloud 控制台中。
- 点击
创建实例模板 。 - 按如下方式选择位置:
- 如果要跨区域使用实例模板,请选择全球级。
- 如果要降低跨区域依赖性,请选择区域级。
- 如果选择区域级,则选择要在其中创建实例模板的区域。
对于以下字段,接受默认值或根据需要进行修改。默认值会根据您所选的机器系列而变化。
- 选择
机器类型 。 - 如需更新启动磁盘类型或映像,请在
启动磁盘 部分中点击更改。 - 如需更新网络接口或 IP 地址设置,请点击
高级选项 ,点击网络,然后点击要修改的网络接口。
- 选择
可选:如果您选择了支持安全强化型虚拟机的映像,请更改虚拟机的安全强化型虚拟机设置:
- 点击高级选项,然后点击安全标签页。
- 如果您要停用安全启动,取消选中开启安全启动复选框。安全启动功能可帮助保护您的虚拟机实例免受启动级和内核级恶意软件和 rootkit 的攻击。如需了解详情,请参阅安全启动。
如果您要停用虚拟可信平台模块 (vTPM),取消选中开启 vTPM 复选框。vTPM 将启用测量启动,该功能可验证虚拟机预启动和启动完整性。如需了解详情,请参阅虚拟可信平台模块 (vTPM)。
如果您要停用完整性监控,请取消选中开启完整性监控复选框。借助完整性监控功能,您可以使用 Cloud Monitoring 监控安全强化型虚拟机实例的启动完整性。如需了解详情,请参阅完整性监控。
可选:在高级选项下,点击相应标签页以进一步自定义模板。例如,您最多可以添加 15 个辅助非启动磁盘。
可选:点击等效 REST 以查看 REST 请求正文,其中包括您的实例模板的 JSON 表示法。
点击创建以创建模板。
- 机器类型:例如
n1-standard-1
- 映像:最新的 Debian 映像
- 启动磁盘:以虚拟机命名的新标准启动磁盘
- 网络:默认 VPC 网络
- IP 地址:临时外部 IPv4 地址
- 堆栈类型:
IPV4_ONLY
INSTANCE_TEMPLATE_NAME
:模板的名称MACHINE_TYPE
:虚拟机的机器类型DISK_IMAGE_FAMILY
:要用作非启动磁盘的映像系列如需详细了解映像系列,请参阅在 Compute Engine 上使用映像系列时的最佳实践。
您可以改用
--image=IMAGE
标志来指定映像的特定版本。对于空白磁盘,请勿指定
image-family
或image
属性。DISK_IMAGE_PROJECT
:映像所属的映像项目对于空白磁盘,请勿指定
image-project
属性。如需详细了解公共映像,请参阅公共映像。SIZE_GB_DISK1
和SIZE_GB_DISK2
:每个辅助磁盘的大小DISK_NAME
(可选):创建虚拟机后向客机操作系统显示的磁盘名称。DISK_TYPE
(可选):要创建的磁盘类型。如果未指定,则使用的默认磁盘类型取决于--machine-type
标志的值。ZONE
和REMOTE_ZONE
:要创建区域磁盘的可用区,以及要将磁盘复制到的目标可用区。对于可用区级磁盘,请勿添加
replica-zones
属性。--no-shielded-secure-boot
:关闭安全启动安全启动功能可帮助保护您的虚拟机实例免受启动级和内核级恶意软件和 rootkit 的攻击。如需了解详情,请参阅安全启动。
--no-shielded-vtpm
:关闭虚拟可信平台模块 (vTPM)vTPM 将启用测量启动,该功能可验证虚拟机预启动和启动完整性。如需了解详情,请参阅虚拟可信平台模块 (vTPM)。
--no-shielded-integrity-monitoring
:关闭完整性监控借助完整性监控功能,您可以使用 Cloud Monitoring 监控安全强化型虚拟机实例的启动完整性。如需了解详情,请参阅完整性监控。
- 使用公共映像或自定义映像创建额外磁盘。
- 如需添加空白磁盘,请定义不带
sourceImage
值的initializeParams
条目。 - 如需创建区域级磁盘,请使用属性
replicaZones
定义initializeParams
条目。 PROJECT_ID
:您的项目 IDREGION
:要创建区域实例模板的区域INSTANCE_TEMPLATE_NAME
:实例模板的名称ZONE
:虚拟机所在的可用区MACHINE_TYPE
:虚拟机的机器类型-
IMAGE_PROJECT
:映像所属的映像项目如需详细了解公共映像,请参阅公共映像。
IMAGE
或IMAGE_FAMILY
:指定以下其中一项:-
IMAGE
:映像的特定版本例如
"sourceImage": "projects/debian-cloud/global/images/debian-10-buster-v20200309"
IMAGE_FAMILY
:映像系列此项表示通过最新的未弃用的操作系统映像创建虚拟机。 例如,如果您指定
"sourceImage": "projects/debian-cloud/global/images/family/debian-10"
,则 Compute Engine 会通过 Debian 10 映像系列中最新版本的操作系统映像创建虚拟机。如需详细了解映像系列,请参阅在 Compute Engine 上使用映像系列时的最佳做法。
-
DISK_NAME
(可选):创建虚拟机后向客机操作系统显示的磁盘名称。PROJECT_NAME
:与虚拟机关联的项目REMOTE_ZONE
:区域级磁盘应复制到的目标可用区指定
initializeParams
可为每个实例创建启动磁盘。您可以使用sourceImage
属性,通过公共镜像或自定义镜像(或镜像系列)来创建磁盘,如前面的示例所示。如需添加空白磁盘,请勿指定sourceImage
。您还可以通过为每个附加磁盘使用initializeParams
属性,最多添加 15 个次级非启动磁盘。指定
source
可挂接现有的启动磁盘。如果挂接现有启动磁盘,则只能通过模板创建一个实例。enableSecureBoot
:开启或关闭安全启动安全启动功能可帮助保护您的虚拟机实例免受启动级和内核级恶意软件和 rootkit 的攻击。如需了解详情,请参阅安全启动。
enableVtpm
:开启或关闭虚拟可信平台模块 (vTPM)vTPM 将启用测量启动,该功能可验证虚拟机预启动和启动完整性。如需了解详情,请参阅虚拟可信平台模块 (vTPM)。
enableIntegrityMonitoring
:开启或关闭完整性监控借助完整性监控功能,您可以使用 Cloud Monitoring 报告监控和验证安全强化型虚拟机实例的运行时启动完整性。如需了解详情,请参阅完整性监控。
INSTANCE_TEMPLATE_NAME
是要创建的模板的名称。SOURCE_INSTANCE
是要用作新模板的模型的实例名称。SOURCE_INSTANCE_ZONE
是包含来源实例的可用区。SOURCE_DISK
是您要在模板中替换的来源实例磁盘的名称。INSTANTIATE_OPTIONS
指定是否添加磁盘以及要使用的映像。有效值取决于磁盘类型,具体如下:source-image
或source-image-family
(仅对启动磁盘和其他永久性读写磁盘有效)。如果要使用用于在来源虚拟机实例中创建磁盘的来源映像或来源映像系列,请指定此选项。custom-image
(仅对启动磁盘和其他永久性读写磁盘有效)。如果要在实例模板中保留来源虚拟机中的应用和设置,您可以创建自定义映像,然后在创建模板时指定该映像。指定时,请提供自定义映像的路径或网址,如以下示例所示。或者,您也可以使用以下格式指定映像系列:--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
(仅对只读磁盘有效)。blank
(仅对非启动永久性磁盘和本地 SSD 有效)。如果已指定,则在使用模板创建新实例时,将创建未格式化的该磁盘。您必须先在启动脚本中格式化并装载该磁盘,然后才能在可扩缩的设置中使用。do-not-include
(仅对非启动永久性磁盘和只读磁盘有效)。
AUTO_DELETE
指定删除实例时是否自动删除磁盘。有效值为false
、no
、true
、yes
。PROJECT_ID
:您的项目 IDINSTANCE_TEMPLATE_NAME
:新模板的名称SOURCE_INSTANCE_ZONE
:来源实例所在的可用区SOURCE_INSTANCE
:要用作此实例模板模型的来源实例的名称SOURCE_DISK
:您要在模板中替换的来源实例磁盘的名称INSTANTIATE_OPTIONS
指定是否添加磁盘以及要使用的映像有效值取决于磁盘类型,具体如下:
source-image
或source-image-family
(仅对启动磁盘和其他永久性读写磁盘有效)。custom-image
(仅对启动磁盘和其他永久性读写磁盘有效)。如果要在实例模板中保留来源虚拟机中的应用和设置,您可以创建自定义映像,然后在创建模板时指定该映像。指定时,请提供自定义映像的路径或网址,如以下示例所示。或者,您也可以使用以下格式指定映像系列:"diskConfigs": [ { "deviceName": DATA_DISK_NAME, "instantiateFrom": custom-image, "customImage": "projects/PROJECT_ID/global/images/family/IMAGE_FAMILY_NAME" } ]
attach-read-only
(仅对只读磁盘有效)。blank
(仅对非启动永久性磁盘和本地 SSD 有效)。如果已指定,则在使用模板创建新实例时,将创建未格式化的该磁盘。您必须先在启动脚本中格式化并装载该磁盘,然后才能在可扩缩的设置中使用。do-not-include
(仅对非启动永久性磁盘和只读磁盘有效)。
- [默认] 使用用于在来源实例中创建启动磁盘的相同来源映像或映像系列。
- 使用前面示例中所述的任何映像(自定义或公共)的网址,或使用以下格式指定映像系列:
- [默认] 使用用于在来源实例中创建磁盘的来源映像/来源映像系列。注意:如果来源实例的磁盘没有来源映像/来源映像系列属性,则系统会将其作为空白磁盘添加到模板中。
- 使用前面示例中所述的任何映像(自定义或公共)的网址,或使用以下格式指定映像系列:
projects/exampleproject/global/images/family/IMAGE_FAMILY_NAME
- 在模板中使用空白磁盘。使用模板创建新实例时,将创建未格式化的此磁盘。 您必须先在启动脚本中格式化并装载该磁盘,然后才能在可扩缩的设置中使用。
- 不添加此磁盘。
- [默认] 添加处于只读模式的磁盘。
- 不添加此磁盘。
- [默认] 添加空白本地 SSD。使用模板创建新实例时,将创建未格式化的此磁盘。您必须先在启动脚本中格式化并装载该磁盘,然后才能在可扩缩的设置中使用。
转到实例模板页面。
点击您要复制和更新的实例模板。
点击创建类似模板。
在新模板中更新配置。
点击创建。
支持所需的 GPU 类型的机器类型。如果要创建区域级实例模板,则您在模板中指定的 GPU 类型必须在该区域的至少一个可用区中可用。
在主机维护事件期间停止虚拟机的维护政策。
在 Google Cloud 控制台中,转到实例模板页面。
点击创建实例模板。
在名称字段中,输入实例模板的名称。
在位置部分,选择以下选项之一:
如需创建全球实例模板,请选择全球(默认)。
如需创建区域级实例模板,请选择区域,然后选择要在其中创建实例模板的区域。
在机器配置部分中,执行以下操作:
点击 GPU 标签页。
在 GPU 类型菜单中,选择 GPU 类型。
在 GPU 数量菜单中,选择 GPU 的数量。
可选:如果您的 GPU 模型支持适用于图形工作负载的 NVIDIA RTX 虚拟工作站 (vWS),并且您计划运行图形密集型工作负载,请选择启用虚拟工作站 (NVIDIA GRID)。
在机器类型部分中,选择一种机器类型。
可选:如需更改启动磁盘类型或映像的默认值,请在启动磁盘部分中,点击更改。然后,按照提示更改启动磁盘。
点击创建。
INSTANCE_TEMPLATE_NAME
:实例模板的名称。IMAGE_PROJECT
:映像所属的映像项目;例如debian-cloud
。如需详细了解支持的映像项目,请参阅公共映像。IMAGE_FAMILY
或IMAGE
:指定以下其中一项:MACHINE_TYPE
:虚拟机的机器类型。如果您指定 N1 机器类型,请添加--accelerator
标志以指定要挂接到虚拟机的 GPU 数量和类型。具有 2 个 vCPU 的 N1 预定义机器类型。
一个要挂接到虚拟机的 NVIDIA T4 GPU。
Debian 作为映像项目。
Debian 10 作为映像系列。
PROJECT_ID
:您希望创建实例模板的项目的 ID。INSTANCE_TEMPLATE_NAME
:实例模板的名称。IMAGE_PROJECT
:映像所属的映像项目;例如debian-cloud
。如需详细了解支持的映像项目,请参阅公共映像。IMAGE
或IMAGE_FAMILY
:指定以下其中一项:MACHINE_TYPE
:虚拟机的机器类型。如果您指定 N1 机器类型,请添加guestAccelerators
字段以指定要挂接到虚拟机的 GPU 数量和类型。具有 2 个 vCPU 的 N1 预定义机器类型。
一个要挂接到虚拟机的 NVIDIA T4 GPU。
Debian 作为映像项目。
Debian 10 作为映像系列。
转到实例模板页面。
点击创建实例模板。
在容器部分中,点击部署容器。
在配置容器对话框中,指定要使用的容器映像。
- 您可以指定 Container Registry 或 Artifact Registry 中的映像。例如:
gcr.io/cloud-marketplace/google/nginx1:TAG
,其中 TAG 是为 Google Cloud Marketplace 上提供的特定 NGINX 容器映像版本定义的标记。us-docker.pkg.dev/google-samples/containers/gke/hello-app:1.0
用于选择 Artifact Registry 中存储的示例hello-app
映像。
- 如果您使用 Docker Hub 中的容器映像,请始终指定完整的 Docker 映像名称。例如,指定以下映像名称以部署一个 Apache 容器映像:
docker.io/httpd:2.4
。
- 您可以指定 Container Registry 或 Artifact Registry 中的映像。例如:
(可选)点击高级容器选项。如需了解详情,请参阅配置选项以便运行容器。
点击创建。
INSTANCE_TEMPLATE_NAME
:要创建的模板的名称。CONTAINER_IMAGE
:要使用的容器映像的全名。INSTANCE_TEMPLATE_NAME
:实例模板的名称REGION
:子网的区域SUBNET_NAME_OR_URL
:子网的名称或网址STACK_TYPE
(可选):在默认网络接口上启用 IPv6 的状态。可以使用以下值:IPV4_ONLY
、IPV4_IPV6
或IPV6_ONLY
(预览版)。如果您不添加此标志,则默认值为IPV4_ONLY
。INSTANCE_TEMPLATE_REGION
:用于创建实例模板的区域。此区域必须与REGION
相同。自定义映像由于 MIG 用于频繁地添加和移除实例,因此创建自定义映像并在实例模板中指定该映像会很有用。您可以在映像中做好准备,使其配备您的实例需要的应用和设置,这样您就不必在 MIG 中的各个虚拟机上手动配置这几项内容。
- 查看实例模板以查看其 ID 和实例属性。
- 通过实例模板创建虚拟机。
- 创建托管式实例组 (MIG)。
- 更新现有 MIG 中的虚拟机以使用其他实例模板中的属性。
- 创建虚拟机预留。
Terraform
如需在本地开发环境中使用本页面上的 Terraform 示例,请安装并初始化 gcloud CLI,然后使用您的用户凭证设置应用默认凭证。
如需了解详情,请参阅 Set up authentication for a local development environment。
Go
如需在本地开发环境中使用本页面上的 Go 示例,请安装并初始化 gcloud CLI,然后使用您的用户凭证设置应用默认凭证。
如需了解详情,请参阅 Set up authentication for a local development environment。 如需了解详情,请参阅身份验证文档中的为本地开发环境设置 ADC。
Java
如需在本地开发环境中使用本页面上的 Java 示例,请安装并初始化 gcloud CLI,然后使用您的用户凭证设置应用默认凭证。
如需了解详情,请参阅 Set up authentication for a local development environment。 如需了解详情,请参阅身份验证文档中的为本地开发环境设置 ADC。
Node.js
如需在本地开发环境中使用本页面上的 Node.js 示例,请安装并初始化 gcloud CLI,然后使用您的用户凭证设置应用默认凭证。
如需了解详情,请参阅 Set up authentication for a local development environment。 如需了解详情,请参阅身份验证文档中的为本地开发环境设置 ADC。
Python
如需在本地开发环境中使用本页面上的 Python 示例,请安装并初始化 gcloud CLI,然后使用您的用户凭证设置应用默认凭证。
如需了解详情,请参阅 Set up authentication for a local development environment。 如需了解详情,请参阅身份验证文档中的为本地开发环境设置 ADC。
REST
如需在本地开发环境中使用本页面上的 REST API 示例,请使用您提供给 gcloud CLI 的凭据。
After installing the Google Cloud CLI, initialize it by running the following command:
gcloud init
If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.
如需了解详情,请参阅 Google Cloud 身份验证文档中的使用 REST 时进行身份验证。
限制
创建实例模板
您在创建单个虚拟机实例的请求中指定的大多数虚拟机属性也可以为实例模板指定,包括任何虚拟机元数据、启动脚本、永久性磁盘和服务账号。您必须指定机器类型、启动磁盘和网络。
通过Google Cloud console、Google Cloud CLI 或 API 创建区域级或全球级实例模板。如需创建全局实例模板,您也可以使用 Terraform 或 Cloud 客户端库。
控制台
gcloud
如需创建区域级或全球实例模板,请使用
instance-templates create
命令。对于区域级实例模板,您必须使用--instance-template-region
标志来设置模板的区域。使用以下命令创建区域级实例模板。
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --instance-template-region=REGION
将
REGION
替换为您要创建区域级实例模板的区域。使用以下命令创建全球实例模板:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME
如果您未提供明确的模板设置,
gcloud compute
将使用以下默认值:您也可以明确提供这些配置设置。例如:
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
您最多可以添加 15 个辅助非启动磁盘。为您创建的每个辅助磁盘指定
--create-disk
标志。如需通过公共映像或自定义映像创建辅助磁盘,请在--create-disk
标志中为每个磁盘指定image
和image-project
属性。如需创建空白磁盘,请勿包含这些属性。您可以酌情添加磁盘属性size
和type
。 如需指定区域级磁盘,请使用replica-zones
属性。gcloud compute instance-templates create INSTANCE_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
提示:指定磁盘参数
replica-zones
时,字符^:^
表示值之间的分隔符是英文冒号 (:
),而不是预期的英文逗号 (,
)。替换以下内容:
如果选择支持受防护的虚拟机的映像,则可以选择使用以下标志之一更改实例的受防护的虚拟机设置:
如需查看所有可用子命令和标志的列表,请参阅
instance-templates
参考文档。采用了默认配置设置的模板可能如下所示:
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
Terraform
如需创建实例模板,您可以使用
google_compute_instance_template
资源。以下 Terraform 示例类似于以下 gcloud CLI 命令:
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
如需了解如何应用或移除 Terraform 配置,请参阅基本 Terraform 命令。
Go
Java
Node.js
Python
REST
如需创建区域级实例模板,请向
regionInstanceTemplates.insert
方法发出POST
请求,如下所示:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/instanceTemplates
如需创建全局实例模板,请向
instanceTemplates.insert
方法发出POST
请求:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/instanceTemplates
使用
disks
属性您最多可以添加 15 个辅助非启动磁盘,每个额外磁盘都有一个字段。对于每个额外磁盘,您可以执行以下操作:在请求正文中,提供模板属性:
{ "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" ] } } ] } }
替换以下内容:
您可以为
disks
属性指定以下选项之一:另外,您也可以视需要为
initializeParams
指定diskSizeGb
、diskType
和labels
属性,为source
指定diskSizeGb
属性。如果选择支持安全强化型虚拟机的映像,则可以视需要使用以下布尔值请求正文项更改虚拟机的安全强化型虚拟机设置:
如需详细了解请求参数,请参阅
instanceTemplates.insert
方法。根据现有实例创建实例模板
您可以使用 REST 或 gcloud CLI 将现有虚拟机实例的配置另存为实例模板。(可选)您可以覆盖模板中定义实例的来源磁盘的方式。
如果您需要覆盖其他属性,请先根据现有实例创建一个实例模板,然后借助其他覆盖创建一个类似模板。
gcloud
使用带有
--source-instance
和--source-instance-zone
标志的gcloud compute instance-templates create
命令。 如果您要创建区域实例模板,则还必须使用--instance-template-region
标志来指定实例模板的区域。如需创建区域实例模板,请使用以下命令:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --source-instance=SOURCE_INSTANCE \ --source-instance-zone=SOURCE_INSTANCE_ZONE \ --instance-template-region=REGION
如需创建全球实例模板,请使用以下命令:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --source-instance=SOURCE_INSTANCE \ --source-instance-zone=SOURCE_INSTANCE_ZONE
如需替换源实例的磁盘定义方式,请添加一个或多个
--configure-disk
标志。以下示例根据现有实例创建全局实例模板,并使用您提供的规范替换源实例的磁盘。
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
替换以下内容:
例如,以下命令会根据
my-source-instance
创建一个实例模板,同时可以选择使用data-disk-a
的原始映像,但将 auto-delete 设置为true
,并将data-disk-b
替换为自定义映像。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
如需创建区域级实例模板,请使用
regionInstanceTemplates.insert
方法;如需创建全局实例模板,请使用instanceTemplates.insert
方法。在请求中,您必须指定
sourceInstance
字段。如需替换如何定义源实例的磁盘,请添加一个或多个diskConfigs
字段。例如,进行以下调用,以根据现有实例创建全球实例模板。
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 } ] } }
替换以下内容:
以下示例将根据
my-source-instance
创建新的实例模板。在实例模板中,data-disk-a
的映像被替换为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" } ] } }
下表显示了在模板中定义覆盖磁盘的选项。
磁盘类型 选项 启动磁盘 projects/exampleproject/global/images/family/IMAGE_FAMILY_NAME
其他读写永久性磁盘 只读磁盘 本地 SSD 对于每个磁盘,您还可以替换
auto-delete
特性 (Attribute),以指定在删除关联实例时是否应删除该磁盘。默认情况下,如果未指定覆盖选项,则模板中的磁盘配置与来源实例一致。
根据现有模板创建实例模板
您无法更新现有实例模板。但是,如果实例模板过期或您需要做出更改,则可以使用控制台,创建另一个具有类似属性的实例模板。
为 GPU 虚拟机创建实例模板
创建实例模板时,您可以通过指定以下内容,将其配置为创建挂接 GPU 的虚拟机:
控制台
如需为 GPU 虚拟机创建实例模板,请执行以下操作:
gcloud
如需为 GPU 虚拟机创建实例模板,请使用
instance-templates create
命令,并将--maintenance-policy
标志设置为TERMINATE
。例如,如需为 GPU 虚拟机创建全局实例模板,请使用以下命令:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --image-project=IMAGE_PROJECT \ --image-family=IMAGE_FAMILY \ --machine-type=MACHINE_TYPE \ --maintenance-policy=TERMINATE
替换以下内容:
例如,假设您要为 GPU 虚拟机创建指定以下属性的全局实例模板:
如需创建示例实例模板,请使用以下命令:
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
如需为 GPU 虚拟机创建实例模板,请使用
google_compute_region_instance_template
资源。例如,若要创建全局实例模板,该模板指定一个 N1 预定义机器类型,具有 2 个 vCPU 和 1 个挂接的 NVIDIA T4 GPU,请使用以下资源:
如需了解如何应用或移除 Terraform 配置,请参阅基本 Terraform 命令。
REST
如需为 GPU 虚拟机创建实例模板,请向
instanceTemplates.insert
方法发出POST
请求。在请求正文中,添加onHostMaintenance
字段并将其设置为TERMINATE
。例如,如需为 GPU 虚拟机创建全局实例模板,请发出
POST
请求,如下所示: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" } } }
替换以下内容:
例如,假设您要为 GPU 虚拟机创建指定以下属性的全局实例模板:
如需创建示例实例模板,请发出如下
POST
请求: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" } } }
如需了解创建实例模板的更多配置选项,请参阅本文档中的创建实例模板。
使用容器映像创建实例模板
您可以在实例模板中指定容器映像。默认情况下,Compute Engine 还会在模板中添加安装了 Docker 的 Container-Optimized OS 映像。当您使用模板创建新实例时,容器会在实例启动时自动启动。
控制台
gcloud
使用
gcloud compute instance-templates create-with-container
命令:gcloud compute instance-templates create-with-container INSTANCE_TEMPLATE_NAME \ --container-image=CONTAINER_IMAGE
替换以下内容:
例如,以下命令会创建一个名为
nginx-vm
的新实例模板。当虚拟机启动时,使用此模板创建的虚拟机实例将启动并运行容器映像gcr.io/cloud-marketplace/google/nginx1:TAG
。gcloud compute instance-templates create-with-container nginx-vm \ --container-image=gcr.io/cloud-marketplace/google/nginx1:TAG
将
TAG
替换为为 Google Cloud Marketplace 上提供的特定 NGINX 容器映像版本定义的标记。此外,您还可以配置选项以便运行容器。
创建可指定子网的实例模板
gcloud
如需创建区域级或全球实例模板,请使用
instance-templates create
命令。使用--subnet
标志可将通过模板创建的实例置入您选择的子网中。--subnet
标志需要与--region
标志搭配使用。如果要创建区域实例模板,则必须使用
--instance-template-region
标志来设置模板的区域。确保使用与要创建区域实例模板相同的区域的子网。gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \ --region=REGION \ --subnet=SUBNET_NAME_OR_URL \ --stack-type=STACK_TYPE \ --instance-template-region=INSTANCE_TEMPLATE_REGION
替换以下内容:
以下示例会创建一个名为
template-qa
的模板,该模板仅在subnet-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
如果使用此模板为 MIG(无论是否启用自动扩缩功能)创建实例,则系统会自动在指定的区域和子网中创建实例。这样一来,您就可以控制为了进行负载均衡而创建的新实例的子网。
在实例模板中使用自定义或公共映像
您可以为实例模板使用自定义映像或公共映像:
与使用启动脚本的虚拟机相比,自定义映像的确定性更高,且启动速度更快。但是,启动脚本更加灵活,可帮助您更新实例中的应用和设置。
如果您要使用映像系列管理映像,则可以在实例模板中指定自定义或公共映像系列的名称。如需详细了解映像系列,请参阅在 Compute Engine 上使用映像系列时的最佳实践。
后续步骤
如未另行说明,那么本页面中的内容已根据知识共享署名 4.0 许可获得了许可,并且代码示例已根据 Apache 2.0 许可获得了许可。有关详情,请参阅 Google 开发者网站政策。Java 是 Oracle 和/或其关联公司的注册商标。
最后更新时间 (UTC):2025-06-23。
-