Performing an in-place upgrade of Windows Server

If you have virtual machine (VM) instances running earlier versions of Windows Server,you can upgrade them to later versions of Windows Server:

Upgrade fromUpgrade to
Windows Server 2008 R2 (Desktop Experience)Windows Server 2012 R2 (Desktop Experience)
Windows Server 2012 R2 (Core)Windows Server 2016 (Core)
Windows Server 2012 R2 (Desktop Experience)Windows Server 2016 (Desktop Experience)
Windows Server 2016 (Core)Windows Server 2019 (Core)
Windows Server 2016 (Desktop Experience)Windows Server 2019 (Desktop Experience)
Windows Server 2019 (Core)Windows Server 2022 (Core)
Windows Server 2019 (Desktop Experience)Windows Server 2022 (Desktop Experience)
Windows Server 2022 (Core)Windows Server 2025 (Core)
Windows Server 2022 (Desktop Experience)Windows Server 2025 (Desktop Experience)

Upgrades are subject to the following constraints:

  • Microsoft hasended support for Windows Server 2012 R2 andWindows Server 2008 R2. If youperform an in-place upgrade of either of these versions and encounterproblems related to the Windows Setup process (setup.exe), Google mightonly be able to provide limited assistance.

  • If you plan to upgrade Windows Server 2008 R2 to a version later thanWindows Server 2012 R2, you must first perform an upgrade to Windows Server2012 R2, and then perform a second upgrade to Windows Server 2016 or later.

  • You must upgrade incrementally, one version at a time, because multipleversion in-place upgrades are not supported.

Important: This guide only describes how to perform an in-place upgrade fromDatacenter editions of Windows Server to Datacenter editions of Windows Server.

Objectives

This guide describes how to perform an in-place upgrade ofWindows Server by:

  1. Planning the in-place upgrade
  2. Performing the in-place upgrade
  3. Troubleshooting the in-place upgrade
  4. Cleaning up after the in-place upgrade

Costs

There is no charge for performing an in-place upgrade of Windows Server. You areonly charged for the resources consumed during the upgrade, including:

Use thepricing calculator to generate a cost estimate based on your projected usage.

Before you begin

The guide assumes that you have basic knowledge of:

Plan the in-place upgrade

Performing an in-place upgrade of a virtual machine (VM) instance that isrunning an earlier version of Windows Server can be a pragmatic way to modernize yourinfrastructure and to mitigate the risks of approaching the end of the support lifecycleof Windows Server versions.

Alternatives to consider

Before you decide to use an in-place upgrade to migrate to a newer version ofWindows Server, be aware of the following limitations:

  • Downtime: Depending on the configuration and software installed, theupgrade might take an hour or longer. During the upgrade, access to the VMinstance is limited because:

    • Workloads running on the VM instance are unavailable to users
    • Remote Desktop Protocol (RDP) is not available
    • There are limited ways to check the upgrade progress and the timeremaining in the upgrade
  • Risk: Depending on the configurations of your existing instances and theinstalled software:

    • The upgrade can fail
    • Some configuration options can be overridden
    • Incompatibilities can cause your workload to malfunction on the upgradedinstance

Depending on the workload running on your Windows Server instance,you can reduce downtime and risk by pursuing different approaches.

WorkloadApproach
Your VM instance is running a workload that supports replication, such as:
  • Active Directory Domain Services
  • DNS
  • SQL Server
Consider setting up a new VM instance that is running a more recent version of Windows Server, and then use replication to shift the workload from your existing VM instance to the new VM instance.
You have a VM instance that is running a multitude of workloadsConsider migrating these workloads to separate VM instances so that each VM instance runs only a single workload. Even if you can't migrate all workloads, reducing the number of workloads running on a single VM instance can help reduce risks during an in-place upgrade.

Product keys

A Windows Server product key is valid for only a specificversion; when you perform an upgrade to a later version of Windows Server, youmust supply a new product key. There are two primary scenarios:

  • You are upgrading a VM instance that is based on apublic operating system image provided by Google: In thisscenario, you must use the predefinedKMS client setup keys for the version of Windows Server that you are upgrading to. The upgradedoes not incur additional charges.

  • You are upgrading a VM instance for which youbrought an existing license: InBYOL,you need to acquire a product key from your license vendor to performthe upgrade.Check the Microsoft documentation to determine which edition you can upgrade toand whether you are eligible for license conversion.

Installation media

To perform the upgrade, you need an installation media. There are two primaryscenarios:

  • You are upgrading a VM instance that is based on apublic operating system image provided by Google: In this scenario, you can use the volume licenseinstallation media provided by Google. The steps to access this installationmedia areprovided below.

  • You are upgrading a VM instance that is based on an imported disk or image:In this scenario, you cannot use the installation media provided by Google.Instead, you have to use an installation media that matches the type ofmedia that you used to install Windows Server on the imported disk or image.

    Important: If you use a custom install media to upgrade to Windows Server2012 R2, make sure todisable animations before using it to perform an upgrade. Disabling animations is critical toprevent theMSOOBE process from causing the upgrade to stop respondingindefinitely.

Other prerequisites

Before you begin your upgrade, review the Microsoft documentation aboutprerequisites and potential limitations for the version of Windows Serveryou are planning to upgrade to:

2012 R2

Year 2016

Year 2019

Year 2022

Year 2025

Perform the in-place upgrade

The following sections guide you through the process of upgrading your VMinstance.

Create a snapshot

Before you start the upgrade, we recommend that youcreate a snapshot of yourVM instance,so that you can revert to a safe state in case anything goes wrong:

Prepare your Windows Server configuration

Verify the configuration of your Windows Server VM instance:

  1. Connect to your VM instance with an RDP client.

  2. Verify that Windows Server is up to dateby using Windows Update.

  3. Disable or uninstall antivirus, antispyware, and other agents that caninterfere with the upgrade or are incompatible with the Windows Serverversion that you're upgrading to.

Attach the install media

Before you can perform the upgrade, attach the necessary installation media to theVM instance. The right media to use depends on your scenario:

  • You are upgrading a VM instance that is based on a public operating systemimage provided by Google: In this scenario, you only need to attach thevolume license installation media provided by Google. This media containsboth the necessary scripts to run the upgrade and the files for the new versionof Windows Server.
  • You are upgrading a VM instance that is based on an imported disk or image:In this scenario, you also need to attach the volume license installation mediaprovided by Google so that you can access the necessary scripts.

    Additionally, you have to attach a custom installation media that matches the type of media thatyou used to install Windows Server on the imported disk or image.

To attach the volume license installation media provided by Google, follow these steps:

  1. In the Google Cloud console, openCloud Shell by clicking theActivate Cloud ShellActivate Cloud Shell.button.

    Go to the Google Cloud console

  2. Set the default project ID. ReplacePROJECT_ID with the name of yourCompute Engine project:

    gcloud config set projectPROJECT_ID
  3. Create a disk based on the installation media. ReplaceZONE with thename of the zone where the VM is located:

    gcloud compute disks create win-installers --image-family=windows-install-media --image-project=compute-image-tools --zone=ZONE

    This command adds a disk namedwin-installers to your project. This diskis not attached to any VM instance.

  4. Attach the disk to your VM by using read-only (ro) mode, so thatyou can attach the disk to multiple VMs if necessary:

    gcloud compute instances attach-diskVM_NAME --disk=win-installers --mode=ro --zone=ZONE

    Replace the following:

    • VM_NAME: the name of the VM instance to upgrade
    • ZONE: the name of the zone where the VM is located

    You can use the same disk for multiple and parallel VM upgradeswithin the same zone, but if you want to upgrade a VM in adifferent zone, you must create another disk in that zone.

If you are upgrading a VM that is based on an imported disk or image,attach the custom installation media as an additional disk:

  1. Follow the steps inCreating an image from an ISO file to create a disk from the ISO image that you want to use as custom installation media.

  2. Attach the disk to your VM, by using read-only (ro) mode so thatyou can attach the disk to multiple VMs if necessary:

    gcloud compute instances attach-diskVM_NAME --disk=CUSTOM_MEDIA_DISK --mode=ro --zone=ZONE

    Replace the following:

    • VM_NAME: the name of the VM to upgrade
    • CUSTOM_MEDIA_DISK: the name of the disk containing your custom installation media
    • ZONE: the name of the zone where the VM is located

Start the upgrade

By default, Windows Setup prompts you for input at various points during anupgrade. Because you can't connect to the VM by using RDP during theupgrade and therefore can't provide any input, run the upgrade inunattended mode.

  1. Connect to your VM with an RDP client. For more information, seeConnecting to instances.

  2. Open an elevated command prompt:

    • If you use Server Core, an elevated command prompt should open automatically after login.
    • If you use Windows Server with full Desktop Experience,right-click theStart button and selectCommand Prompt (Admin).
  3. Change the working directory to the installation media. The correct workingdirectory depends on the Windows Server version that you are upgrading to:

    2012 R2

    cd /d d:\*2012*

    Year 2016

    cd /d d:\*2016*

    Year 2019

    cd /d d:\*2019*

    Year 2022

    cd /d d:\*2022*

    Year 2025

    cd /d d:\*2025*
    Important: Adjust the drive letter if Windows assigned a different letterthanD: to the disk containing the volume license installation mediaprovided by Google.
  4. Start the Windows upgrade. The required steps to start the upgradedepend on the Windows Server version that you are upgrading to and whetheryour VM is based on a public operating system image or onan imported disk or image:

    2012 R2

    Runupgrade.ps1 to start the Windows upgrade. The script completes thefollowing steps:

    • Install the latestGoogle driver packages,which are critical for the Windows Server upgrade to succeed.
    • Apply Windows settings that are required forCompute Engine.
    • Enable access to theEmergency Management Services (EMS) console during the upgrade.
    • Launch Windows Setup (setup.exe) from the install media to perform an upgrade in unattended mode.
    • Selects the correct edition of Windows Server 2012 R2 to install.
    • Provides the Generic Volume License Key (GVLK) for the new version of Windows Server.
    powershell -ExecutionPolicy Bypass -File upgrade.ps1

    2012 R2 (BYOL)

    Runupgrade.ps1 to start the Windows upgrade. The script completes thefollowing steps:

    • Install the latestGoogle driver packages,which are critical for the Windows Server upgrade to succeed.
    • Apply Windows settings that are required forCompute Engine.
    • Enable access to theEmergency Management Services (EMS) console during the upgrade.
    • Launch Windows Setup (setup.exe) from the install media to perform an upgrade in unattended mode.
    • Selects the correct edition of Windows Server 2012 R2 to install.
    • Provides the user provided license key for the new version of Windows Server.
    powershell -ExecutionPolicy Bypass -File upgrade.ps1 -SetupExePathSETUP_PATH -ProductKeyPRODUCT_KEY

    Replace the following:

    • SETUP_PATH: the path tosetup.exe on your custom installation media
    • PRODUCT_KEY: a valid product key for Windows Server 2016.

    The-ProductKey parameter is only required ifyou are upgrading a VM instance for which you brought an existing license (BYOL)

    2016 or later

    Runupgrade.ps1 to start the Windows upgrade. The script completes thefollowing steps:

    • Install the latestGoogle driver packages,which are critical for the Windows Server upgrade to succeed.
    • Apply Windows settings that are required forCompute Engine.
    • Enable access to theEmergency Management Services (EMS) console during the upgrade.
    • Launch Windows Setup (setup.exe) from the install media to perform an upgrade in silent mode.
    • Provide a product key for the new version of Windows Server.
    powershell -ExecutionPolicy Bypass -File upgrade.ps1

    In some cases, Windows Setup might show aSelect Image screen. If yousee this screen, select the configuration that matches yourcurrent configuration:

    • If you use Server Core, selectDatacenter.
    • If you use Windows Server with full desktop experience, selectDatacenter (Desktop Experience).

    • ClickNext to begin the upgrade.

    It might take several minutes for the setup to initialize.

    2016 or later (imported)

    Runupgrade.ps1 to start the Windows upgrade. The script completes thefollowing steps:

    powershell -ExecutionPolicy Bypass -File upgrade.ps1 -SetupExePathSETUP-PATH -ProductKeyPRODUCT-KEY

    Replace the following:

    • SETUP_PATH: the path tosetup.exe on yourcustom installation media
    • PRODUCT_KEY: a valid product key for theversion of Windows Server that is being upgraded to. For example, ifupgrading from Windows Server 2016 Datacenter to Windows Server 2019Datacenter, provide a valid Windows Server 2019 Datacenter key.

    The-ProductKey parameter is only required if you are upgrading a VM instancefor which you brought an existing license (BYOL).

    In some cases, Windows Setup might show aSelect Image screen. If yousee this screen, select the configuration that matches yourcurrent configuration:

    • If you use Server Core, selectWindows Server Datacenter.
    • If you use Windows Server with full desktop experience, selectWindows Server Datacenter (Desktop Experience).

    • ClickNext to begin the upgrade.

    It might take several minutes for the setup to initialize.

    The upgrade process might issue the following warning. If so, you canignore it:

    [package name] or a newer version is already installed on the system

    The system can become temporarily unresponsive while installing thenetkvm driver. If this happens, don't close the RDP connection or stop theVM instance unless the system is unresponsive for more than 5 minutes. Ifyou do lose RDP connectivity, wait approximately 5 minutes before youreconnect to the VM instance.

    The Setup Wizard might require you to restart the system first. Inthis case, restart the VM instance and run Windows Setup again, using thesame command.

    After about 5 minutes, the machine reboots, and RDP disconnects.

Observe the upgrade process

Depending on the machine type of your VM instance and your Windows Serverconfiguration, the upgrade might take between 10 and 60 minutes to complete.During that time, you can observe the status through theserial port output:

  1. In Cloud Shell, observe the boot process by running the following command:

    gcloud compute instances tail-serial-port-outputVM_NAME --zone=ZONE

    Replace the following:

    • VM_NAME: name of your VM instance
    • ZONE: name of the zone where the VM instance is located
  2. Wait until the machine has rebooted four times. Depending on theconfiguration of your VM instance, it might take 30 minutes or morefor these reboots to occur. You can recognize a reboot by output thatlooks similar to this:

    SeaBIOS (version 1.8.2-20190620_103534-google)Total RAM Size = 0x00000001e0000000 = 7680 MiBCPUs found: 2     Max CPUs supported: 2
  3. After the fourth reboot, wait until the outputGCEMetadataScripts: Finished running startup scripts orNo startup scripts to run appears.

Perform post-upgrade steps

You can now connect to the VM instance to verify that the upgrade has beensuccessfully completed.

  1. Connect to the VM instance by using an RDP client. For more information,seeConnecting to instances.

  2. Sign in using a user account with local administrator privileges.

  3. Open an elevated command prompt:

    • If you use Server Core, an elevated command prompt should open automatically after login.
    • If you use Windows Server with full desktop experience,right-click theStart button and selectCommand Prompt (Admin).
  4. Run the following command to query the version of Windows Server:

    Windows Server Core

    ver

    Windows Server with Desktop Experience

    winver

    Verify that the version matches the expected version of Windows Server.

  5. Change the working directory to the installation media. The correct workingdirectory depends on the Windows Server version that you are upgrading to:

    2012 R2

    cd /d d:\*2012*

    Year 2016

    cd /d d:\*2016*

    Year 2019

    cd /d d:\*2019*

    Year 2022

    cd /d d:\*2022*

    Year 2025

    cd /d d:\*2025*
    Important: Adjust the drive letter if Windows assigned a different letterthanD: to the disk containing the volume license installation mediaprovided by Google.
  6. Runupgrade.ps1 again to re-apply specificCompute Engine settings that might have been lost duringthe upgrade:

    powershell -ExecutionPolicy Bypass -File upgrade.ps1
  7. Restart the VM instance to ensure all changes take effect. It might take1 to 2 minutes for the reboot to complete before you can connect to the VMinstance again.

Detach the installation disk

You can now detach the installation disk from the VM instance:

Install updates and restore access

After the upgrade is complete, run Windows Update to download and install anysecurity updates. To install the security updates, follow these steps:

  1. Connect to the machine by using an RDP client. For more information, seeConnecting to instances.

  2. Use Windows Update toinstall the latest Windows updates.You might have to restart the VM instance multiple timesduring this process.

  3. Re-enable any agents, antivirus, or antimalware software that you disabledbefore the upgrade.

Troubleshoot the in-place upgrade

While running Windows Setup, you can't connect to the VM instance with RDP. Ifyou suspect that the upgrade failed or is not progressing, use the followingapproaches, in order, to diagnose the situation:

Check the serial port output

To check the progress of the upgrade process, view theserial port output of the VM instance:

  • Serial port 1 captures the boot status
  • Serial port 3 captures the log output of Windows Setup

During the upgrade, you should observe four reboots. If you don't observe anyprogress for more than 30 minutes after the first reboot, it is likely that theupgrade failed.

Check CPU and I/O metrics

Running a Windows Server upgrade is a CPU and disk I/O intensive operation. Bychecking the CPU and I/O metrics, you can get an indication for whether thesetup is progressing.

View the CPU and I/O metrics in the Google Cloud console:

  1. In the Google Cloud console, go to theVM instances page.

    Go to VM instances

  2. Click the instance that you're upgrading.

  3. Click theMonitoring tab.

Connect to the Emergency Management Services console

Both during and after running Windows Setup, you can connect to theEmergency Management Services (EMS) console.Using the EMS console, check theWindows Setup log files and theevent log for indications that the upgrade is still progressing or for information aboutany errors that might have occurred.

Connect remotely by using WinRM

If connecting by using RDP or EMS fails, you can try using WinRM to establish aremote PowerShell session:

  1. Connect to a different Windows Server instance in the sameVPC.

  2. Open PowerShell.

  3. Establish a remote PowerShell session, replacingVM_NAMEwith the name of the instance to upgrade:

    Enter-PSSession -ComputerNameVM_NAME -UseSSL -SessionOption (New-PsSessionOption -SkipCACheck) -Credential (Get-Credential)
  4. When prompted for credentials, enter the username and password of anadministrative user account.

  5. Use the remote PowerShell session to check theWindows Setup log files and theevent log.

Analyze log files offline

If you can't connect to the instance by using Windows Remote Management (WinRM),you can cancel the upgrade and analyze the log files from a different VMinstance. To do this, follow these steps:

  1. Stop the VM instance.

    This can take several minutes if Windows Server is unresponsive.

  2. Detach the boot disk from the instance.

  3. Create a new, temporary Windows Server instance, and attach the boot disk ofthe original instance as an additional disk.

  4. Use the temporary Windows Server instance to analyze thesetup log and event log files of the instance that you were trying to upgrade.

  5. After you have completed the analysis, detach the disk from the temporaryinstance andreattach it as a boot disk to the original VM instance.

Troubleshoot RDP

For information about troubleshooting RDP, seeTroubleshooting RDP.

Troubleshoot your Windows Server instances

For information about troubleshooting your Windows Server instances, seeTips and troubleshooting for Windows instances.

Clean up

To avoid incurring further costs after you have completed this process, deletethe installation disk.

Delete the installation disk

You can create an installation disk based on the Google-provided image at anytime. If you don't plan to upgrade more VM instances in the same zone, deletethe installation disk:

  • In Cloud Shell, delete thewin-installers disk that you createdearlier:

    gcloud compute disks delete win-installers

What's next

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-12-15 UTC.