Create and start a Compute Engine instance

Compute Engine lets you create and runinstances on Google infrastructure.This document explains how to create a Compute Engine instance.

The termsCompute Engine instance,compute instance orinstance are synonymous. Based on themachine typethat you specify, an instance can be either a bare metal instanceor a virtual machine (VM) instance, as follows:

  • If the name of its machine type ends in-metal, an instance is abare metal instance, which does not have a hypervisor installed.
  • Otherwise, an instance is a VM instance. The termsvirtual machine instance,VM instance, andVM are synonymous.

Synonymous terms are used interchangeablyacross the documentation and Google Cloud interfaces such as theGoogle Cloud console, thegcloud command-line tool,and theREST API.

The instructions in this document only introduce you to instance creation andprovide a starting point for creating an instance. For detailed steps to createinstances with specific or complicated configurations, see instead theCreate and start instances with specific configurations.

Before you begin

Required roles

To get the permissions that you need to create instances, ask your administrator to grant you theCompute Instance Admin (v1) (roles/compute.instanceAdmin.v1) IAM role on the project. For more information about granting roles, seeManage access to projects, folders, and organizations.

This predefined role contains the permissions required to create instances. To see the exact permissions that are required, expand theRequired permissions section:

Required permissions

The following permissions are required to create instances:

  • compute.instances.create on the project
  • To use a custom image to create the VM: compute.images.useReadOnly on the image
  • To use a snapshot to create the VM: compute.snapshots.useReadOnly on the snapshot
  • To use an instance template to create the VM: compute.instanceTemplates.useReadOnly on the instance template
  • To specify a subnet for your VM: compute.subnetworks.use on the project or on the chosen subnet
  • To specify a static IP address for the VM: compute.addresses.use on the project
  • To assign an external IP address to the VM when using a VPC network: compute.subnetworks.useExternalIp on the project or on the chosen subnet
  • To assign alegacy network to the VM: compute.networks.use on the project
  • To assign an external IP address to the VM when using a legacy network: compute.networks.useExternalIp on the project
  • To set VM instance metadata for the VM: compute.instances.setMetadata on the project
  • To set tags for the VM: compute.instances.setTags on the VM
  • To set labels for the VM: compute.instances.setLabels on the VM
  • To set a service account for the VM to use: compute.instances.setServiceAccount on the VM
  • To create a new disk for the VM: compute.disks.create on the project
  • To attach an existing disk in read-only or read-write mode: compute.disks.use on the disk
  • To attach an existing disk in read-only mode: compute.disks.useReadOnly on the disk

You might also be able to get these permissions withcustom roles or otherpredefined roles.

Methods to create and start an instance

This section introduces the basic methods that you can use to create and starta Compute Engine instance. Specifically, while you are learning how tocreate an instance, we recommend that you use the Google Cloud console, theGoogle Cloud CLI, or the REST API. To learn about the general process forcreating an instance using each of these methods, review the followinginstructions.

Important: The instructions in this section are provided for learning purposes.For detailed steps to create and start an instance, see the followingCreate and start instances with specific configurationssection in this document instead.

Console

  1. In the Google Cloud console, go to theCreate an instance page.

    Go to Create an instance

    TheCreate an instance screen appears and displays theMachine configuration pane.

  2. To configure instance properties, use the options in the navigation menuas follows.

    Tip: For a summary of the options in the navigation menu, seeConfiguration options during instance creation.
    1. To configure instance properties related to name, location, or machineconfiguration, clickMachine configuration. In theMachine configuration pane that appears, specify values for theproperties that you want to configure.

    2. To configure instance properties related to boot disk, operating system(OS), and additional non-boot storage options, click theOS and storage. In theOperating system and storage pane that appears, specifyvalues for the properties that you want to configure.

    3. To configure instance properties related to network interface and firewallsettings, clickNetworking. In theNetworking pane thatappears, specify values for the properties that you want to configure.

    4. To configure instance properties related to Ops agent and virtual displays,clickObservability. In theObservability pane thatappears, specify values for the properties that you want to configure.

    5. To configure instance properties related to security and access, clickSecurity. In theSecurity pane that opens, specify values forthe properties that you want to configure.

    6. To configure instance properties related to metadata, reservations,resource organization, provisioning type, and sole-tenancy, clickAdvanced. In theAdvanced pane that opens, specify values forthe properties that you want to configure.

  3. To create and start your instance, clickCreate.

gcloud

To create an instance with your own configuration, use thegcloud compute instances create command.

You can't use this command to createinstances in bulk orinstances that run container images.Instead, do the following:

REST

To create an instance with your own configuration, make aPOSTrequest to theinstances.insert method.

You can't use this method to createinstances in bulk.Instead, make aPOST request to theinstances.bulkInsert method.

Tip: You can generate the code to create an instance for Google Cloud CLI,REST, or Terraform by using theEquivalent code button on theCreate an instance page in the Google Cloud console. Generating code canhelp you learn syntax and prevent errors. Learn more aboutGoogle Cloud console features for Compute Engine.

Create and start instances with specific configurations

Each of the following documents provides instructions for how to create andstart an instance that uses one or more specific configuration options. Basedon your use case, you can create an instance that uses configuration optionsfrom multiple documents by combining the instructions. To learn about thevarious parameters that you can configure while creating your instance, reviewConfiguration options available during instance creation.

Preconfigured for you
Create a Google-configured, workload-optimized instance
Customized machine configuration
Create an instance with a custom hostname
Create an instance with a custom machine type
Create an instance with attached GPUs
Specify a minimum CPU platform for an instance
Customized OS configuration
Create an instance from a public image
Create an instance from a custom image
Create an instance from a shared image
Create an instance using a RHEL BYOS image
Customized networking configuration
Create an instance in a specific subnet
Create an instance that uses IPv6 addresses
Create instances that use the gVNIC network interface
Configure an instance with higher bandwidth
Customized observability configuration
Create an instance that's configured for Ops Agent monitoring and logging
Enable virtual displays on an instance
Customized security configuration
Create an instance that uses a user-managed service account
Create VMs with managed workload identities enabled
Enable OS Login during VM creation
Configured for disaster recovery
Create an instance with a Backup and DR backup plan
From a backup
Create an instance from a machine image
Create an instance from a disk snapshot
Restore an instance from a backup vault
From existing configurations
Create an instance from an instance template
Create an instance similar to an existing instance
Configured for specific workloads
Create an instance to deploy a container
Create Windows Server instances
Create SQL Server instances
Create an instance with a high performance computing (HPC) image
Customized provisioning type
Create a Spot instance
Create instances that consume reserved instances
Multiple instances at once
Create instances in bulk
Create a managed instance group (MIG)
Sole-tenant nodes
Create instances on sole-tenant nodes
Efficient instances
Create an instance with an attached instance schedule

Troubleshooting

To find methods for resolving common instance creation errors, seeTroubleshooting instance creation.

What's next?

Try it for yourself

If you're new to Google Cloud, create an account to evaluate how Compute Engine performs in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.

Try Compute Engine free

Except as otherwise noted, the content of this page is licensed under theCreative Commons Attribution 4.0 License, and code samples are licensed under theApache 2.0 License. For details, see theGoogle Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.

Last updated 2025-10-02 UTC.