本文档介绍如何创建使用 Spot 虚拟机的代管式实例组 (MIG)。
Spot 虚拟机是您可以以极低折扣价获得的虚拟机 (VM) 实例。不过,Compute Engine 可以随时停止或删除 Spot 虚拟机来收回容量。您可以使用 Spot 虚拟机以低成本运行容错型工作负载,例如批处理作业或无状态应用。
如需了解可用于创建 MIG 的其他方法,请参阅创建 MIG 的基本场景。
准备工作
- 验证您有足够的配额用于要请求的资源。如需了解详情,请参阅分配配额。
- 验证您要在其中创建 Spot 虚拟机的区域或可用区中是否有可用资源。检查资源可用性有助于降低您在创建虚拟机时遇到资源可用性错误的几率。如需了解相关说明,请参阅查看 Spot 虚拟机的可用性。
-
如果您尚未设置身份验证,请进行设置。身份验证用于验证您的身份,以便访问 Cloud de Confiance by S3NS 服务和 API。如需从本地开发环境运行代码或示例,您可以通过选择以下选项之一向 Compute Engine 进行身份验证:
选择标签页以了解您打算如何使用本页面上的示例:
控制台
当您使用 Cloud de Confiance 控制台访问 Cloud de Confiance by S3NS 服务和 API 时,无需设置身份验证。
gcloud
-
安装 Google Cloud CLI,然后 使用联合身份登录 gcloud CLI。 登录后,运行以下命令来初始化 Google Cloud CLI:
gcloud init
-
- 设置默认区域和可用区。
REST
如需在本地开发环境中使用本页面上的 REST API 示例,请使用您提供给 gcloud CLI 的凭证。
安装 Google Cloud CLI,然后 使用联合身份登录 gcloud CLI。
如需了解详情,请参阅 Cloud de Confiance 身份验证文档中的使用 REST 时进行身份验证。
所需的角色
如需获得创建使用抢占式虚拟机的 MIG 所需的权限,请让您的管理员为您授予项目的 Compute Instance Admin (v1) (roles/compute.instanceAdmin.v1) IAM 角色。
如需详细了解如何授予角色,请参阅管理对项目、文件夹和组织的访问权限。
此预定义角色包含创建使用抢占式虚拟机的 MIG 所需的权限。如需查看所需的确切权限,请展开所需权限部分:
所需权限
如需创建使用 Spot 虚拟机的 MIG,您需要具备以下权限:
-
如需创建实例模板:针对项目的
compute.instanceTemplates.create权限 -
如需创建 MIG:针对项目的
compute.instanceGroupManagers.create权限
创建使用 Spot 虚拟机的 MIG
如需创建使用 Spot 虚拟机的 MIG,您必须完成以下步骤:
创建配置为创建 Spot 虚拟机的实例模板
如需创建配置为创建 Spot 虚拟机的实例模板,请选择以下选项之一:
控制台
在 Cloud de Confiance 控制台中,转到实例模板页面。
点击创建实例模板。 系统会显示创建实例模板页面。
在名称字段中,输入实例模板的名称。
在位置部分中,选择要创建的实例模板类型:
对于区域级实例模板,请选择区域,然后选择要在其中创建模板的区域。根据您希望抢占式虚拟机使用的机器类型,指定一个支持的区域。
对于全球实例模板,请选择全球。
在机器配置部分中,为 Spot 虚拟机选择支持的机器系列。
在预配模型部分中,执行以下操作:
在虚拟机预配模型列表中,选择 Spot。
如需指定在抢占时是停止还是删除 Spot 虚拟机,请在虚拟机终止时列表中选择以下选项之一:
如需停止 Spot 虚拟机,请选择停止。
如需删除 Spot 虚拟机,请选择删除。
可选:如需更改启动磁盘类型或映像的默认值,请在启动磁盘部分中,点击更改。然后,按照提示更改启动磁盘。
点击创建。
gcloud
如需创建配置为创建竞价型虚拟机的实例模板,请使用 gcloud compute instance-templates create 命令。
以下命令会创建一个区域级实例模板。如果您要创建全球实例模板,请使用相同的命令,但不使用 --instance-template-region 标志。
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \
--image-project=IMAGE_PROJECT \
--image-family=IMAGE_FAMILY \
--instance-template-region=REGION \
--instance-termination-action=TERMINATION_ACTION \
--machine-type=MACHINE_TYPE \
--provisioning-model=SPOT
替换以下内容:
INSTANCE_TEMPLATE_NAME:要创建的实例模板的名称。IMAGE_PROJECT:映像所属的映像项目;例如debian-cloud。如需详细了解支持的映像项目,请参阅公共映像。IMAGE_FAMILY:映像系列。此项指定最新的未弃用操作系统映像。例如,如果您指定debian-12,则系统会使用 Debian 12 映像系列中的最新版本。如需详细了解如何使用映像系列,请参阅映像系列最佳实践。REGION:用于创建实例模板的区域。根据您希望竞价型虚拟机使用的机器类型,指定支持的区域。TERMINATION_ACTION:指示 Compute Engine 在抢占时是停止还是删除 Spot 虚拟机。您必须指定是停止 (STOP) 还是删除 (DELETE) 虚拟机。MACHINE_TYPE:适用于 Spot 虚拟机的受支持机器类型。如果您指定 N1 机器类型,则必须添加--accelerator标志以定义要挂接到虚拟机的 GPU 的数量和类型。
REST
如需创建配置为创建 Spot 虚拟机的实例模板,请发出以下 POST 请求之一:
如需创建区域级实例模板:
regionInstanceTemplates.insert方法如需创建全球实例模板:
instanceTemplates.insert方法
例如,如需创建区域级实例模板,请发出如下请求:
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/instanceTemplates
{
"name": "INSTANCE_TEMPLATE_NAME",
"properties": {
"disks": [
{
"boot": true,
"initializeParams": {
"sourceImage": "projects/IMAGE_PROJECT/global/images/IMAGE"
}
}
],
"machineType": "MACHINE_TYPE",
"networkInterfaces": [
{
"network": "global/networks/default"
}
],
"scheduling": {
"instanceTerminationAction": "TERMINATION_ACTION",
"provisioningModel": "SPOT"
}
}
}
替换以下内容:
PROJECT_ID:要创建实例模板的项目 ID。REGION:用于创建实例模板的区域。根据您希望竞价型虚拟机使用的机器类型,指定支持的区域。INSTANCE_TEMPLATE_NAME:实例模板的名称。IMAGE_PROJECT:映像所属的映像项目;例如debian-cloud。如需详细了解支持的映像项目,请参阅公共映像。IMAGE:指定以下其中一项:MACHINE_TYPE:适用于 Spot 虚拟机的受支持机器类型。如果您指定 N1 机器类型,则必须添加guestAccelerators字段以定义要挂接到虚拟机的 GPU 的数量和类型。TERMINATION_ACTION:指示 Compute Engine 在抢占时是停止还是删除 Spot 虚拟机。您必须指定是停止 (STOP) 还是删除 (DELETE) 虚拟机。
创建实例模板后,您可以查看模板的详细信息以查看其属性。
创建区域级或可用区级 MIG
如需创建区域级或可用区级 MIG,请选择以下选项之一:
控制台
在 Cloud de Confiance 控制台中,前往实例群组页面。
点击创建实例组。 此时会打开创建实例组页面。
在名称字段中,输入 MIG 的名称。
在实例模板列表中,选择您在上一部分中创建的实例模板。
在实例数字段中,输入要在 MIG 中创建的竞价型虚拟机的数量。如果您的工作负载需要具有特定名称的虚拟机,请按
0以跳过此阶段的虚拟机创建。创建 MIG 后,向其中添加具有特定名称的虚拟机。在位置部分中,指定您是要创建可用区级 MIG 还是区域级 MIG,如下所示:
如需创建可用区级 MIG,请选择单个可用区。或者,如需创建区域 MIG,请选择多个可用区。
为 MIG 选择区域和可用区。
点击创建。
gcloud
如需创建 MIG,请使用 gcloud compute instance-groups managed create 命令。
根据要创建的 MIG 类型,在命令中添加以下标志:
如需创建可用区级 MIG,请添加
--zone标志:gcloud compute instance-groups managed create INSTANCE_GROUP_NAME \ --size=SIZE \ --template=INSTANCE_TEMPLATE_URL \ --zone=ZONE如需创建区域级 MIG,请添加
--region标志:gcloud compute instance-groups managed create INSTANCE_GROUP_NAME \ --size=SIZE \ --template=INSTANCE_TEMPLATE_URL \ --region=REGION
替换以下内容:
INSTANCE_GROUP_NAME:MIG 的名称。INSTANCE_TEMPLATE_URL:您在上一部分中创建的实例模板的网址。网址可以包含实例模板的 ID 或名称。请指定以下某个值:对于区域级实例模板:
projects/PROJECT_ID/regions/REGION/instanceTemplates/INSTANCE_TEMPLATE_ID对于全球实例模板:
INSTANCE_TEMPLATE_ID
SIZE:要在 MIG 中创建的 Spot 虚拟机数量。如果您的工作负载需要特定的虚拟机名称,请指定0以跳过在此阶段创建虚拟机。创建 MIG 后,向其中添加具有特定名称的虚拟机。ZONE:要用于创建可用区级 MIG 的可用区。如果您使用区域级实例模板创建 MIG,则必须指定与该模板位于同一区域内的可用区。REGION:要创建区域级 MIG 的区域。如果您使用区域级实例模板创建 MIG,则必须指定与模板的区域相同的区域。
REST
如需创建 MIG,请向以下方法之一发出 POST 请求:
如需创建可用区级 MIG,请向
instanceGroupManagers.insert方法发出POST请求:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instanceGroupManagers { "name": "INSTANCE_GROUP_NAME", "versions": [ { "instanceTemplate": "INSTANCE_TEMPLATE_URL" } ], "targetSize": SIZE }如需创建区域级 MIG,请向
regionInstanceGroupManagers.insert方法发出POST请求:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/instanceGroupManagers { "name": "INSTANCE_GROUP_NAME", "instanceTemplate": "INSTANCE_TEMPLATE_URL", "targetSize": SIZE }
替换以下内容:
PROJECT_ID:要在其中创建区域级或可用区级 MIG 的项目的 ID。ZONE:要用于创建可用区级 MIG 的可用区。如果您使用区域级实例模板创建 MIG,则必须指定与该模板位于同一区域内的可用区。REGION:要创建区域级 MIG 的区域。如果您使用区域级实例模板创建 MIG,则必须指定与模板的区域相同的区域。INSTANCE_GROUP_NAME:MIG 的名称。INSTANCE_TEMPLATE_URL:您在上一部分中创建的实例模板的网址。网址可以包含实例模板的 ID 或名称。请指定以下某个值:对于区域级实例模板:
projects/PROJECT_ID/regions/REGION/instanceTemplates/INSTANCE_TEMPLATE_ID对于全球实例模板:
INSTANCE_TEMPLATE_ID
SIZE:要在 MIG 中创建的竞价型虚拟机的数量。如果您的工作负载需要特定的虚拟机名称,请指定0以跳过在此阶段创建虚拟机。创建 MIG 后,向其中添加具有特定名称的虚拟机。
创建 MIG 后,您可以查看 MIG 的详细信息,以查看其属性。
后续步骤
详细了解 Spot 虚拟机的最佳实践。
详细了解如何修复 MIG 中的虚拟机以实现高可用性。
详细了解如何自动扩缩 MIG 中的虚拟机。
详细了解有状态 MIG。