Home

Awesome

Welcome to Azure Virtual Desktop (AVD) Session Host Replacer

Overview

This tool automates the deployment and replacement of session hosts in an Azure Virtual Desktop host pool.

The best practice for AVD recommends replacing the session hosts instead of maintaining them, AVD Session Host Replacer helps you manage the task of replacing old session hosts with new ones automatically.

AVD Session Host Replacer vs AVD Session Host Update (Preview)

Session Host Update is a native feature that enables you to update the session hosts in a host pool. It is currently in preview. Below is a comparison of the two features,

PointSession Host Update (Preview)AVD Session Host Replacer
SupportOfficially supported by Microsoft (once out of preview)Community supported (GitHub issues)
AvailabiltyPublic Cloud OnlyAll clouds including Gov and China
Entra Join
Customize ARM Template for VM deployment
Replacement OrderRemove old VMs > Deploy new VMs* Deploy new VMs > Remove old VMs
Initial test deployment* ❌
Session Host VM NameChanges after replacement to reflect the dateMaintains the names as per defined prefix
Change total number of session hosts (scale out/in)
TriggerBased on schedulesBased on criteria (Image Version, VM Age)
MonitoringNative Azure DiagnosticsFunction App logging in Log Analytics

* If you need these feature please use GitHub issues to request them.

Getting started

Pre-requisites

The Session Host Replacer requires permissions to manage resources in Azure and, if the session hosts are Entra joined, permissions in Entra. The recommended approach is to create a User Managed Identity, assign the necessary permissions to it, and use it for all instances of the Session Host Replacer.

If you do not select a User Managed Identity, the deployment will create a System Managed Identity and assign permissions to it. However, some additional permissions may need to be assigned manually after deployment. This is not recommended if you have more than one instance of the Session Host Replacer.

Detailed instructions on the required permissions and how to assign them are available here.

Deployment

Deployment TypeLink
Azure Portal UIDeploy to Azure Deploy to Azure Gov Deploy to Azure China
Command line (Bicep/ARM)Powershell/Azure CLI
Offline Deployment (no GitHub)Offline Deployment

How it works?

There are two criteria for replacing a session host,

  1. Image Version: Is there a new image version available? If so, we create a new session host with the new image version. This can be from Marketplace or Gallery Image Definition.
  2. Session Host VM Age: If the session host is older than a certain age, default is 45 days, we create a new session host and drain the old one.

The core of an AVD Session Host Replacer is an Azure Function App built using PowerShell, the function is triggered every hour to check each session host against the above criteria.

To deploy new session hosts, the function uses an ARM Template that is stored as a Template Spec at deployment time.

When deleting an old session host, the function will check if it has existing sessions and,

  1. Place the session host drain mode.
  2. Send a notification to all sessions.
  3. Add a tag to the session host with a timestamp
  4. Delete the session host once there are no sessions or the grace period has passed.
    • Delete VM
    • Remove from Host Pool
    • (If Entra Joined) Delete device from Entra ID

FAQ

Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.