Enabling Remote Work

Configure Windows Virtual Desktop (WVD) to use FSLogix profile containers as a user profile storage

Table of Contents

In this blog, I’m going to show you how to configure profiles in Azure Windows virtual desktop, and how to set up FSLogix profile service with Azure Windows virtual desktop. Okay first a little bit about FSlogix, FSlogix is now part of Microsoft and Microsoft is making the product available for profile management in Windows virtual desktops, this is a good thing per Microsoft documentation user profile disks are being depreciated.

Benefits of Installing FSLogix on WVD

  1. FSLogix profile containers are high performance and resolve performance issues that have historically blocked cached exchange mode.
  2. Without FSLogix profile containers, OneDrive for Business is not supported in non-persistent RDSH or VDI environments.
  3. Maintain user context in non-persistent environments
  4. Minimize sign in times for non-persistent environments
  5. Optimize file IO between host/client and remote profile store
  6. Native (Local) profile experience, eliminating many compatibility issues with solutions using visible redirection, such as User Profile Disk (UPD).
  7. Simplify the management of applications and ‘Gold Images’
  8. Specify the version of Java to be utilized by specific URL and applications

I’m going to go over the basics of FSlogix installation using file shares to hold profile containers this is the process outlined in Microsoft documentation. So this is the plan I have a managed image with all my software just like we did in the last blog ( WVD Golden image Customization and updates using Shared Image Gallery ) I’m going to deploy that to a new VM and configure FS logic that will then be turned into a managed image.

So with that here’s what I’m going to cover in the demo

  1. Prepare a virtual machine to act as a file share for user profiles
  2. Grant the Windows Virtual Desktop users with the required Permissions on the created share.
  3. Deploy a new VM from the template
  4. Install and configure FSlogix software
  5. Convert that VM to a new template
  6. Deploy the Windows virtual desktop pool using the new template
  7. Test the profiles

Prepare a virtual machine to act as a file share for user profiles

Add the Windows Virtual Desktop Active Directory users to an Active Directory security group. This security group will be used to authenticate the Windows Virtual Desktop users to the file share virtual machine you just created.

Grant the Windows Virtual Desktop users with the required Permissions on the created share

Create a new folder, Right-click the new folder, select Properties, select Sharing, then select Advanced sharing…. Select Share this folder, select Permissions…, then select Add…., Search for the security group to which you added the Windows Virtual Desktop users,

Then make sure that group has Full Control. 

After adding the security group, right-click the folder, select Properties, select Sharing, then copy down the Network Path to use for later.

  

Deploy a new VM from the template

Open Create a virtual machine blade

  • Subscription: Select the subscription where the new VM will be created.
  • Resource group: Create a new resource group or use an existing one.
  • Virtual machine name: Enter a name for the Master virtual machine (Ex. WVD-MSTR-FSX)
  • Region: Select the (Region) where you want to create the host pool.
  • Availability Zone: (1,2,3)
  • Image: Select the image created in previous article (Azure Shared Image Gallery and Windows Virtual Desktop) (Ex. WVDPRDSIG/WVD-Master01-image-20200818/latest – Gen1)
  • Size: Select VM Size (Ex. D2s_V3)
  • License Type: Windows Client

 

For the rest of configuration, you can follow the ( Step 2: Create VM from the created Managed Disk )

Install and configure FSlogix software

Configure FSlogix software: Option 1 (Manuel values creation using Regedit)

  1. Download the FSLogix agent using this link
  2. Extract the right Release (64 or 32) and run FSLogixAppsSetup to install the FSLogix agent.

  1. From the start menu, run RegEdit as an administrator. Navigate to Computer\HKEY_LOCAL_MACHINE\software\FSLogix.
  2. Create a key named Profiles.
  3. Create the following values for the Profiles key:
Name Type Data/Value
Enabled DWORD 1
VHDLocations Multi-String Value “Network path for file share”

Configure FSlogix software: Option 2 (Registry file)

Just follow the Same Steps in option 1 from 1 to 4

Then you have to download and install this Registry file

Modify VHDLocations with “Network path for file share”

Configure FSlogix software: Option 3 (Use FSLogix Group Policy (GPO) Template Files)

  1. Connect to Domain Controller
  2. Download the FSLogix agent using this link
  3. Extract the right Release (64 or 32)
  4. Copy the ADMX file (fslogix.admx) to C:\Windows\PolicyDefinitions
  5. Copy the ADML file (fslogix.adml) to C:\Windows\PolicyDefinitions\en-US
  6. Run GPEDIT.MSC
  7. Create New GPO and linked to WVD OU

  8. Browse to Computer Configuration > Policies > Administrative Templates > FSLogix > Profile Containers > VHD Location (Enable it)
  9. Modify VHDLocations with “Network path for file share”

  • Browse to Computer Configuration > Policies > Administrative Templates > FSLogix > Profile Containers > Enabled (Enable it)
  • NOTE: Windows Virtual Desktop doesn’t require an open inbound port 3389 for users to access the host pool’s VMs. We don’t recommend to open inbound port 3389 on your WVD VMs.

Convert that VM to a new template

Follow the same Step that we highlighted earlier in Azure Shared Image Gallery and Windows Virtual Desktop to

  1. Sysprep and Create a Virtual Machine Capture

  1. Add an image to the Shared Image Gallery

Deploy the Windows virtual desktop pool using the new template

Just like we have done before in this article (Deploy a Windows Virtual Desktop Host pool with the custom image) Please follow this section to Creating your new host pool

  • Select Image Type Gallery
  • Click on Browse all images and disks > My Items > Click on the Latest Image (Ex. WVD-MSTR-FSX-image-20200830172419)
  • Rest of Steps are same like previous article (Creating your new host pool)

Verify FSLogix Profile Container on File Share.

Access Assignments

Go to Assignments under Newly created Hostpool Application group and assign WVD Users Group.

Access Testing Profile Creation Varication

Logon as a specific user and check if the Profile Container is being created on the File Share. See the example below.

Verify Profile Creation through WVD Session host.

Verify Profile Creation through File Share.

Azure Files integration with Azure Active Directory Domain Service

FSLogix profile containers’ performance and features take advantage of the cloud. On August 7th, 2019, Microsoft Azure Files announced the general availability of Azure Files authentication with Azure Active Directory Domain Service (AD DS). By addressing both cost and administrative overhead, Azure Files with Azure AD DS Authentication is a premium solution for user profiles in the Windows Virtual Desktop service.

Best practices for Windows Virtual Desktop

Windows Virtual Desktop offers full control over size, type, and count of VMs that are being used by customers. To ensure your Windows Virtual Desktop environment follows best practices:

  • Azure Files storage account must be in the same region as the session host VMs.
  • Azure Files permissions should match permissions described in Requirements – Profile Containers.
  • Each host pool must be built of the same type and size VM based on the same master image.
  • Each host pool VM must be in the same resource group to aid management, scaling and updating.
  • For optimal performance, the storage solution and the FSLogix profile container should be in the same data center location.
  • The storage account containing the master image must be in the same region and subscription where the VMs are being provisioned.
Mahmoud A. ATALLAH

Microsoft MVP | Speaker | Azure Service Delivery Lead at Bespin Global MEA, helping customers build successful Azure practices. Talks about #AzureCloud and #AI

Recent Posts

One-Click Deployment of n8n on Azure with Automation Scripts (Step-by-Step)

Introduction to n8n: Flexible Automation with Azure Integration n8n is a flexible, open-source workflow automation…

3 months ago

Top Tools to Automatically Generate Azure Resource Architecture Diagrams

Maintaining accurate, up‑to‑date documentation of your Azure resource architecture is essential in today's rapidly evolving…

6 months ago

Gitex – Ensuring a Secure & Scalable AI-powered Solution with Azure

In this session, we will explore the architecture and best practices for building secure and…

1 year ago

Part 4: Data Exfiltration Playbook – Azure WAF Security Lab

Introduction Welcome to our comprehensive series on Azure Web Application Firewall (WAF) security! In this…

1 year ago

Part 3: Vulnerability Exploitation Playbook – Azure WAF vs XSS

Introduction Welcome to the third installment of our Azure Web Application Firewall (WAF) Security Lab…

1 year ago

Part 2: Reconnaissance Playbook – Testing Azure WAF Protection

Introduction Welcome to the second installment of our Azure Web Application Firewall (WAF) Security Lab…

1 year ago