This document describes how to create a managed instance group (MIG) that preserves the data on disks with a given device name for all of the MIG's VMs, even in the event of VM recreation—for example when a VM in the MIG is autohealed, updated, or recreated. Preserving disks is useful for certain workloads—for example, for databases or legacy applications.
In addition to preserving disks for all VMs in the group, you can also configure a stateful MIG for the following:
- You can add and preserve instance-specific disks.
- You can add and preserve instance-specific metadata.
- You can add and preserve IP addresses.
For more information, see the stateful MIG overview.
You can also read about other basic scenarios for creating a MIG.
Before you begin
- Create an instance template, which is required in order to create a managed instance group.
-
If you haven't already, then set up authentication.
Authentication is
the process by which your identity is verified for access to Google Cloud services and APIs.
To run code or samples from a local development environment, you can authenticate to
Compute Engine by selecting one of the following options:
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.
Terraform
To use the Terraform samples on this page in a local development environment, install and initialize the gcloud CLI, and then set up Application Default Credentials with your user credentials.
- 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.
For more information, see Set up authentication for a local development environment.
REST
To use the REST API samples on this page in a local development environment, you use the credentials you provide to the gcloud CLI.
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
For more information, see Authenticate for using REST in the Google Cloud authentication documentation.
-
Limitations
A MIG with stateful configuration—a stateful MIG—has the following limitations:
- You cannot use autoscaling if your MIG has stateful configuration.
- If you want to use automated rolling updates, you must set the
replacement method
to
RECREATE
. - For stateful regional MIGs, you must
disable proactive redistribution
(set the redistribution type to
NONE
) to prevent deletion of stateful instances by automatic cross-zone redistribution. - If you use an all-instances configuration to override instance template properties, you cannot specify those properties in any per-instance configuration and at the same time in the group's all-instances configuration.
To see the full list of MIG limitations, which varies based on the configuration that you use, see MIG limitations.
Create a MIG with stateful disks
Use the Google Cloud console, the gcloud CLI, Terraform, or REST.
Console
-
Go to the Instance groups page.
The remaining steps appear in the Google Cloud console.
-
Click
Create instance group . -
Select the
New managed instance group (stateful) option. - Assign a name and optionally a description to your instance group.
- Choose an instance template for the instance group or create a new one.
- In the
Number of instances field, specify the initial number of VMs you need in this group. - In the
Stateful configuration section, under Group config, click the disk you want to make stateful, then perform the following steps. - In the Stateful section, select Yes.
- In the On permanent instance deletion list, choose whether you want to detach the disk or delete the disk when you permanently delete the VM.
- To save the settings, click Done.
- To create the MIG, click
Create .
gcloud
To specify which disks from the instance template should be stateful on MIG
creation, use the --stateful-disk
flag with the
gcloud compute instance-groups managed create
command:
gcloud compute instance-groups managed create INSTANCE_GROUP_NAME \ --template INSTANCE_TEMPLATE \ --size SIZE \ --stateful-disk device-name=DEVICE_NAME[,auto-delete=DELETE_RULE]
Replace the following:
INSTANCE_GROUP_NAME
: The name of the managed instance group to create.INSTANCE_TEMPLATE
: The name of the instance template to use when creating instances. For a regional instance template, you must specify the full or partial URL of the template. An example of a full URL ishttps://www.googleapis.com/compute/v1/projects/example-project/regions/us-central1/instanceTemplates/example-regional-instance-template
and a partial URL isprojects/example-project/regions/us-central1/instanceTemplates/example-regional-instance-template
.SIZE
: The initial number of VMs you need in this group.DEVICE_NAME
: The device name of a disk specified in the instance template.DELETE_RULE
: A value that prescribes what should happen to a stateful disk when a VM is deleted. Available options are:never
: (Default.) Never delete the disk; instead, detach the disk when its VM is deleted.on-permanent-instance-deletion
: Delete the disk when its VM instance is permanently deleted from the instance group, for example, when the managed instance is deleted manually or when the group size is decreased.
Regardless of the value of the delete rule, stateful disks are always preserved on VM autohealing, update, and recreation operations.
Terraform
If you haven't already created an instance template, which specifies the machine type, boot disk image, network, and other VM properties that you want for each VM in your MIG, create an instance template.
To specify which disks from the instance template should be stateful on MIG
creation, include the stateful_disk
block. The following sample creates a
zonal MIG with stateful disks. For more information about the resource that
is used in the sample, see google_compute_instance_group_manager
resource.
To learn how to apply or remove a Terraform configuration, see Basic Terraform commands.
REST
To specify which disks from the instance template should be stateful on MIG
creation, include them in the statefulPolicy
field in your request body.
For a zonal MIG, use the
instanceGroupManagers.insert
method
or for a regional MIG, use the
regionInstanceGroupManagers.insert
method.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT/zones/ZONE/instanceGroupManagers { "name": "NAME", "versions": [ { "instanceTemplate": "global/instanceTemplates/TEMPLATE" } ], "targetSize": SIZE, "statefulPolicy": { "preservedState": { "disks": { "DEVICE_NAME": {"autoDelete": "DELETE_RULE" }, "DEVICE_NAME": {"autoDelete": "DELETE_RULE" } } } } }
Replace the following:
PROJECT
: The project ID for the request.ZONE
: The zone where the MIG is located (applies to a zonal MIG).- For a regional MIG, replace
zones/ZONE
withregions/REGION
and specify the region of the MIG.
- For a regional MIG, replace
NAME
: The name of the MIG to create.TEMPLATE
: The name of the instance template to use when creating instances.SIZE
: The initial number of instances you need in this group.DEVICE_NAME
: The device name of a disk specified in the instance template.DELETE_RULE
: A value that prescribes what should happen to the stateful disk when the VM instance is deleted. The available options are:never
: (Default.) Never delete the disk; detach the disk when the VM is deleted.on_permanent_instance_deletion
: Delete the stateful disk when its VM is permanently deleted from the instance group, for example, when the managed instance is deleted manually or when the group size is decreased.
Regardless of the value of the delete rule, stateful disks are always preserved on instance autohealing, update, and recreation operations.
What's next
- Learn more about stateful MIGs and when to use them.
- Learn more about configuring stateful disks in MIGs.
- Learn How stateful MIGs work.
- Learn more about configuring stateful MIGs for disks, metadata, and IP addresses.