This page describes known issues that you might run into while using Compute Engine. For issues that specifically affect Confidential VMs, see Confidential VM limitations.
General issues
The following issues provide troubleshooting guidance or general information.
IPv6-only C3 VM unreachable during live migration
An IPv6-only VM that uses a C3 machine type might become unreachable during live migration.
Workaround:
To make it less likely that you encounter this issue, you can update the
maintenance policy for the instance and set the
maintenance behavior
to TERMINATE
and automatic restart to TRUE
.
If your VM undergoes live migration and you experience this issue, then restart the VM to regain access to the instance.
Long baseInstanceName
values in managed instance groups (MIGs) can cause disk name conflicts
In a MIG, disk name conflicts can occur if the instance template specifies disks
to be created upon VM creation and the baseInstanceName
value exceeds 54
characters. This happens because Compute Engine generates disk names using the
instance name as a prefix.
When generating disk names, if the resulting name exceeds the resource name limit of 63 character limit, Compute Engine truncates the excess characters from the end of instance name. This truncation can lead to the creation of identical disk names for instances that have similar naming patterns. In such a case, the new instance will attempt to attach the existing disk. If the disk is already attached to another instance, the new instance creation fails. If the disk is not attached or is in multi-writer mode, the new instance will attach the disk, potentially leading to data corruption.
To avoid disk name conflicts, keep the baseInstanceName
value to a maximum
length of 54 characters.
Creating reservations or future reservation requests using an instance template that specifies an A2, C3, or G2 machine type causes issues
If you use an instance template that specifies an A2, C3, or G2 machine type to create a reservation, or to create and submit a future reservation request for review, you encounter issues. Specifically:
Creating the reservation might fail. If it succeeds, then one of the following applies:
If you created an automatically consumed reservation (default), creating VMs with matching properties won't consume the reservation.
If you created a specific reservation, creating VMs to specifically target the reservation fails.
Creating the future reservation request succeeds. However, if you submit it for review, Google Cloud declines your request.
You can't replace the instance template used to create a reservation or future reservation request, or override the template's VM properties. If you want to reserve resources for A2, C3, or G2 machine types, do one of the following instead:
Create a new single-project or shared reservation by specifying properties directly.
Create a new future reservation request by doing the following:
If you want to stop an existing future reservation request from restricting the properties of the future reservation requests you can create in your current project—or in the projects the future reservation request is shared with—delete the future reservation request.
Create a single-project or shared future reservation request by specifying properties directly and submit it for review.
Limitations when using c3-standard-*-lssd
and c3d-standard-*-lssd
machine types with Google Kubernetes Engine
When using the Google Kubernetes Engine API, the node pool
with Local SSD attached that you provision must have the same number of
SSD disks as the selected C3 and C3D machine type. For example, if you plan
to create a VM that uses the c3-standard-8-lssd
there must be 2 SSD disks,
whereas for a c3d-standard-8-lssd
, just 1 SSD disk is required. If the
disk number doesn't match you will get a Local SSD misconfiguration error
from the Compute Engine control plane. See the
General-purpose machine family
document to select the correct number of Local SSD disks based on the C3 or C3D
lssd
machine type.
Using the Google Kubernetes Engine Google Cloud console to create a cluster or node pool
with c3-standard-*-lssd
and c3d-standard-*-lssd
VMs results in node creation
failure or a failure to detect Local SSDs as ephemeral storage.
Single flow TCP throughput variability on C3D VMs
C3D VMs larger than 30 vCPUs might experience single flow TCP throughput variability and occasionally be limited to 20-25 Gbps. To achieve higher rates, use multiple tcp flows.
The CPU utilization observability metric is incorrect for VMs that use one thread per core
If your VM's CPU uses one thread per core, the CPU utilization Cloud Monitoring observability metric in the Compute Engine > VM instances > Observability tab only scales to 50%. Two threads per core is the default for all machine types, except Tau T2D. For more information, see Set number of threads per core.
To view your VM's CPU utilization normalized to 100%, view CPU utilization in Metrics Explorer instead. For more information, see Create charts with Metrics Explorer.
Google Cloud console SSH-in-browser connections might fail if you use custom firewall rules
If you use custom firewall rules to control SSH access to your VM instances, you might not be able to use the SSH-in-browser feature.
To work around this issue, do one of the following:
Enable Identity-Aware Proxy for TCP to continue connecting to VMs using the SSH-in-browser Google Cloud console feature.
Recreate the
default-allow-ssh
firewall rule to continue connecting to VMs using SSH-in-browser.Connect to VMs using the Google Cloud CLI instead of SSH-in-browser.
Downsizing or deleting specific reservations stops VMs from consuming other reservations
If you downsize or delete a specific reservation that was consumed by one or more VMs, the orphaned VMs cannot consume any reservations.
Optionally, to prevent this issue, delete VMs or update the
reservationAffinity
property of VMs until the number of VMs targeting the specific reservation matches the number of VMs planned for the specific reservation. After, you can downsize or delete the specific reservation.To fix this issue:
Make the number of VMs in the specific reservation equal to the number of VMs that are targeting it by doing one or more of the following: deleting VMs, updating the
reservationAffinity
property of VMs, upsizing the downsized reservation, or recreating the deleted specific reservation.Stop and start any remaining VMs.
Learn more about deleting reservations and resizing reservations.
Moving VMs or disks using the moveInstance
API or the gcloud CLI causes unexpected behavior
Moving virtual machine (VM) instances using the gcloud compute instances move
command or the
project.moveInstance
method
might cause data loss, VM deletion, or other unexpected behavior.
To move VMs, we recommend that you follow the instructions in Move a VM instance between zones or regions.
Disks attached to VMs with n2d-standard-64
machine types don't consistently reach performance limits
Persistent disks attached to VMs with n2d-standard-64
machine types don't
consistently reach the maximum performance limit of 100,000 IOPS. This is the
case for both read and write IOPS.
Temporary names for disks
During virtual machine (VM) instance updates initiated using the
gcloud compute instances update
command
or the
instances.update
API method,
Compute Engine might temporarily change the name of your VM's disks, by adding
of the following suffixes to the original name:
-temp
-old
-new
Compute Engine removes the suffix and restores the original disk names as the update completes.
Increased latency for some Persistent Disks caused by disk resizing
In some cases, resizing large Persistent Disks (~3 TB or larger) might be disruptive to the I/O performance of the disk. If you are impacted by this issue, your Persistent Disks might experience increased latency during the resize operation. This issue can impact Persistent Disks of any type.
Your automated processes might fail if they use API response data about your resource-based commitment quotas
Your automated processes that consume and use API response data about your Compute Engine resource-based commitment quotas might fail if each of the following things happen. Your automated processes can include any snippets of code, business logic, or database fields that use or store the API responses.
The response data is from any of the following Compute Engine API methods:
You use an
int
instead of anumber
to define the field for your resource quota limit in your API response bodies. You can find the field in the following ways for each method:items[].quotas[].limit
for thecompute.regions.list
method.quotas[].limit
for thecompute.regions.get
method.quotas[].limit
for thecompute.projects.get
method.
You have unlimited default quota available for any of your Compute Engine committed SKUs.
For more information about quotas for commitments and committed SKUs, see Quotas for commitments and committed resources.
Root cause
When you you have limited quota, if you define the items[].quotas[].limit
or
quotas[].limit
field as an int
type, the API response data for your quota
limits might still fall within the range for int
type and your automated
process might not get disrupted. But when the default quota limit is unlimited,
Compute Engine API returns a value for the limit
field that falls
outside of the range defined by int
type. Your automated process can't
consume the value returned by the API method and fails as a result.
How to work around this issue
You can work around this issue and continue generating your automated reports in the following ways:
Recommended: Follow the Compute Engine API reference documentation and use the correct data types for the API method definitions. Specifically, use the
number
type to define theitems[].quotas[].limit
andquotas[].limit
fields for your API methods.Decrease your quota limit to a value under 9,223,372,036,854,775,807. You must set quota caps for all projects that have resource-based commitments, across all regions. You can do this in one of the following ways:
- Follow the same steps that you would to place a quota increase request, and request for a lower quota limit.
- Set a consumer quota override.
Known issues for Linux VM instances
These are the known issues for Linux VMs.
SUSE Enterprise VM fail to boot after changing instances types
After changing a SUSE Linux Enterprise VM's instance type it can fail to boot with the following error seen repeating in the serial console:
Starting [0;1;39mdracut initqueue hook[0m...
[ 136.146065] dracut-initqueue[377]: Warning: dracut-initqueue: timeout, still waiting for following initqueue hooks:
[ 136.164820] dracut-initqueue[377]: Warning: /lib/dracut/hooks/initqueue/finished/devexists-\x2fdev\x2fdisk\x2fby-uuid\x2fD3E2-0CEB.sh: "[ -e "/dev/disk/by-uuid/D3E2-0CEB" ]"
[ 136.188732] dracut-initqueue[377]: Warning: /lib/dracut/hooks/initqueue/finished/devexists-\x2fdev\x2fdisk\x2fby-uuid\x2fe7b218a9-449d-4477-8200-a7bb61a9ff4d.sh: "if ! grep -q After=remote-fs-pre.target /run/systemd/generator/systemd-cryptsetup@*.service 2>/dev/null; then
[ 136.220738] dracut-initqueue[377]: [ -e "/dev/disk/by-uuid/e7b218a9-449d-4477-8200-a7bb61a9ff4d" ]
[ 136.240713] dracut-initqueue[377]: fi"
Root cause
SUSE creates its cloud images with a versatile initramfs
(initial RAM filesystem) that
supports various instance types. This is achieved by using the
--no-hostonly --no-hostonly-cmdline -o multipath
flags during the initial
image creation. However, when a new kernel is installed or the initramfs
is
regenerated, which happens during system updates, these flags are omitted by default.
This results in a smaller initramfs
tailored specifically for the current system's
hardware, potentially excluding drivers needed for other instance types.
For example, C3 instances use NVMe drives, which require specific modules
to be included in the initramfs
. If a system with an initramfs
lacking these NVMe
modules is migrated to a C3 instance, the boot process fails. This issue
can also affect other instance types with unique hardware requirements.
Workaround
Before changing the machine type, regenerate the initramfs
with all drivers:
dracut --force --no-hostonly
If the system is already impacted by the issue create a
temporary rescue VM. Use the chroot
command to
access the impacted VM's boot disk then regenerate the initramfs
using the following
command:
dracut -f --no-hostonly
Lower IOPS performance for Local SSD on Z3 with SUSE 12 images
Z3 VMs on SUSE Linux Enterprise Server (SLES) 12 images have significantly less than expected performance for IOPS on Local SSD disks.
Root cause
This is an issue within the SLES 12 codebase.
Workaround
A patch from SUSE to fix this issue is not available or planned. Instead, you should use the SLES 15 operating system.
RHEL 7 and CentOS VMs lose network access after reboot
If your CentOS or RHEL 7 VMs have multiple network interface cards (NICs) and one of these NICs doesn't use the VirtIO interface, then network access might be lost on reboot. This happens because RHEL doesn't support disabling predictable network interface names if at least one NIC doesn't use the VirtIO interface.
Resolution
Network connectivity can be restored by
stopping and starting the VM
until the issue resolves. Network connectivity loss can be prevented from
reoccurring by doing the following:
1. Edit the /etc/default/grub
file and remove the kernel parameters
net.ifnames=0
and biosdevname=0
.
2. Regenerate the grub configuration.
3. Reboot the VM.
Missing symlinks for Local SSD devices on C3 and C3D VMs running SUSE Linux
Public Google Cloud SUSE images don't include the required udev configuration to create symlinks for C3 and C3D Local SSD devices.
Resolution
To add udev rules for SUSE and custom images, see Symlinks not created C3 and C3D with Local SSD.
repomd.xml signature couldn't be verified
On Red Hat Enterprise Linux (RHEL) or CentOS 7 based systems, you might see the following error when trying to install or update software using yum. This error shows that you have an expired or incorrect repository GPG key.
Sample log:
[root@centos7 ~]# yum update
...
google-cloud-sdk/signature | 1.4 kB 00:00:01 !!!
https://packages.cloud.google.com/yum/repos/cloud-sdk-el7-x86_64/repodata/repomd.xml: [Errno -1] repomd.xml signature could not be verified for google-cloud-sdk
Trying other mirror.
...
failure: repodata/repomd.xml from google-cloud-sdk: [Errno 256] No more mirrors to try.
https://packages.cloud.google.com/yum/repos/cloud-sdk-el7-x86_64/repodata/repomd.xml: [Errno -1] repomd.xml signature could not be verified for google-cloud-sdk
Resolution
To fix this, disable repository GPG key checking in the yum repository configuration
by setting repo_gpgcheck=0
. In supported Compute Engine base images this
setting might be found in /etc/yum.repos.d/google-cloud.repo
file. However,
your VM can have this set in different repository configuration files
or automation tools.
Yum repositories don't usually use GPG keys for repository validation. Instead,
the https
endpoint is trusted.
To locate and update this setting, complete the following steps:
Look for the setting in your
/etc/yum.repos.d/google-cloud.repo
file.cat /etc/yum.repos.d/google-cloud.repo [google-compute-engine] name=Google Compute Engine baseurl=https://packages.cloud.google.com/yum/repos/google-compute-engine-el7-x86_64-stable enabled=1 gpgcheck=1 repo_gpgcheck=1 gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg [google-cloud-sdk] name=Google Cloud SDK baseurl=https://packages.cloud.google.com/yum/repos/cloud-sdk-el7-x86_64 enabled=1 gpgcheck=1 repo_gpgcheck=1 gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
Change all lines that say
repo_gpgcheck=1
torepo_gpgcheck=0
.sudo sed -i 's/repo_gpgcheck=1/repo_gpgcheck=0/g' /etc/yum.repos.d/google-cloud.repo
Check that the setting is updated.
cat /etc/yum.repos.d/google-cloud.repo [google-compute-engine] name=Google Compute Engine baseurl=https://packages.cloud.google.com/yum/repos/google-compute-engine-el7-x86_64-stable enabled=1 gpgcheck=1 repo_gpgcheck=0 gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg [google-cloud-sdk] name=Google Cloud SDK baseurl=https://packages.cloud.google.com/yum/repos/cloud-sdk-el7-x86_64 enabled=1 gpgcheck=1 repo_gpgcheck=0 gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
Instances using OS Login return a login message after connection
On some instances that use OS Login, you might receive the following error message after the connection is established:
/usr/bin/id: cannot find name for group ID 123456789
Resolution
Ignore the error message.
Known issues for Windows VM instances
- Support for NVMe on Windows using the Community NVMe driver is in Beta, the performance might not match that of Linux instances. The Community NVMe driver has been replaced with the Microsoft StorNVMe driver in Google Cloud public images. We recommend that you replace the NVME driver on VMs created before May 2022 and use the Microsoft StorNVMe driver instead.
- After you create an instance, you cannot connect to it instantly. All new Windows instances use the System preparation (sysprep) tool to set up your instance, which can take 5–10 mins to complete.
- Windows Server images cannot activate without a network connection to
kms.windows.googlecloud.com
and stop functioning if they don't initially authenticate within 30 days. Software activated by the KMS must reactivate every 180 days, but the KMS attempts to reactivate every 7 days. Make sure to configure your Windows instances so that they remain activated. - Kernel software that accesses non-emulated model specific registers will generate general protection faults, which can cause a system crash depending on the guest operating system.
Windows Server 2025 and Windows 11 24h2 - Suspend and resume support
Windows Server 2025 and Windows 11 24h2 are unable to resume when suspended. Until this issue is resolved, the suspend and resume feature won't be supported for Windows Server 2025 and Windows 11 24h2.
Errors when measuring NTP time drift using w32tm on Windows VMs
For Windows VMs on Compute Engine running VirtIO NICs, there is a known bug where measuring NTP drift produces errors when using the following command:
w32tm /stripchart /computer:metadata.google.internal
The errors appear similar to the following:
Tracking metadata.google.internal [169.254.169.254:123].
The current time is 11/6/2023 6:52:20 PM.
18:52:20, d:+00.0007693s o:+00.0000285s [ * ]
18:52:22, error: 0x80072733
18:52:24, d:+00.0003550s o:-00.0000754s [ * ]
18:52:26, error: 0x80072733
18:52:28, d:+00.0003728s o:-00.0000696s [ * ]
18:52:30, error: 0x80072733
18:52:32, error: 0x80072733
This bug only impacts Compute Engine VMs with VirtIO NICs. VMs that use gVNIC don't encounter this issue.
To avoid this issue, Google recommends using other NTP drift measuring tools, such as the Meinberg Time Server Monitor.
Inaccessible boot device after updating a VM from Gen 1 or 2 to a Gen 3+ VM
Windows Server binds the boot drive to its initial disk interface type upon first startup. To change an existing VM from an older machine series that uses a SCSI disk interface to a newer machine series that uses an NVMe disk interface, perform a Windows PnP driver sysprep before shutting down the VM. This sysprep only prepares device drivers and ensures all disk interface types are scanned for the boot drive on the next start.
To update the machine series of a VM, do the following:
From a Powershell prompt as Administrator
run:
PS C:\> start rundll32.exe sppnp.dll,Sysprep_Generalize_Pnp -wait
- Stop the VM.
- Change the VM to the new VM machine type.
- Start the VM.
If the new VM doesn't start correctly, change the VM back to the original machine type in order to get your VM running again. It should start successfully. Review the migration requirements to ensure you meet them. Then retry the instructions.
Limited bandwidth with gVNIC on Windows VMs
The packaged gVNIC driver on the Windows images offered by Compute Engine can achieve up to 50 Gbps of network bandwidth on Windows Instances, for both standard network performance and per VM Tier_1 networking performance. An updated version of the gVNIC driver can deliver line-rate performance (up to 200 Gbps) and support for Jumbo frames.
The updated driver is only available for third generation and later machine series (excluding N4). For more information, see Update the gVNIC version on Windows OS.
Limited disk count attachment for newer VM machine series
VMs running on Microsoft Windows with the NVMe disk interface, (which includes T2A, all third generation and newer VMs, and VMs using Confidential Computing), have a disk attachment limit of 16 disks. To avoid errors, consolidate your Persistent Disk and Hyperdisk storage to a maximum of 16 disks per VM. Local SSD storage is excluded from this issue.
Replace the NVME driver on VMs created before May 2022
If you want to use NVMe on a VM that uses Microsoft Windows, and the VM was created prior to May 1, 2022, you must update the existing NVMe driver in the Guest OS to use the Microsoft StorNVMe driver.
You must update the NVMe driver on your VM before you change the machine type to a third generation machine series, or before creating a boot disk snapshot that will be used to create new VMs that use a third generation machine series.
Use the following commands to install the StorNVME driver package and remove the community driver, if it's present in the guest OS.
googet update
googet install google-compute-engine-driver-nvme
Lower performance for Local SSD on Microsoft Windows with C3 and C3D VMs
Local SSD performance is limited for C3 and C3D VMs running Microsoft Windows.
Performance improvements are in progress.
Poor networking throughput when using gVNIC
Windows Server 2022 and Windows 11 VMs that use gVNIC driver GooGet package
version 1.0.0@44
or earlier might experience poor networking throughput when
using Google Virtual NIC (gVNIC).
To resolve this issue, update the gVNIC driver GooGet package to version
1.0.0@45
or later by doing the following:
Check which driver version is installed on your VM by running the following command from an administrator Command Prompt or Powershell session:
googet installed
The output looks similar to the following:
Installed packages: ... google-compute-engine-driver-gvnic.x86_64 VERSION_NUMBER ...
If the
google-compute-engine-driver-gvnic.x86_64
driver version is1.0.0@44
or earlier, update the GooGet package repository by running the following command from an administrator Command Prompt or Powershell session:googet update
C3D 180 and 360 vCPU machines types don't support Windows OS images
C3D 180 vCPU machines types don't support Windows Server 2012 and 2016 OS images. C3D VMs created with 180 vCPUs and Windows Server 2012 and 2016 OS images will fail to boot. To workaround this issue, select a smaller machine type or use another OS image.
C3D VMs created with 360 vCPUs and Windows OS images will fail to boot. To work around this issue, select a smaller machine type or use another OS image.
Generic disk error on Windows Server 2016 and 2012 R2 for M3, C3, and C3D VMs
The ability to add or resize a Hyperdisk or Persistent Disk for a running M3, C3, or C3D VM doesn't work as expected on specific Windows guests at this time. Windows Server 2012 R2 and Windows Server 2016, and their corresponding non-server Windows variants, don't respond correctly to the disk attach and disk resize commands.
For example, removing a disk from a running M3 VM disconnects the disk from a Windows Server instance without the Windows operating system recognizing that the disk is gone. Subsequent writes to the disk return a generic error.
Resolution
You must restart the M3, C3, or C3D VM running on Windows after modifying a Hyperdisk or Persistent Disk for the disk modifications to be recognized by these guests.