This post contains some example WMI filters for you to use in Group Policy Objects (GPOs) to target and manage specific Windows Server versions like 2012R2, 2016 and Windows Server 2019.
Using the Windows Management Infrastructure, or WMI, Windows admins can create filters to apply GPOs more granular on specific versions of Windows Server. In this post I provide some basic examples.
If you use PowerShell 5.1, you can verify WMI filters with
Get-WmiObject in the Win32_OperatingSystem class:
PS C:\> Get-WmiObject -Class Win32_OperatingSystem | Select Version, ProductType
PS C:\> Get-WmiObject -Class Win32_OperatingSystem | Select Version,Name,ProductType
Selecting Name, it’s easy to select Windows Server 2012 R2. It’s recommended to use a LIKE sub-selection
Select Name From Win32_OperatingSystem Where Name Like '%Windows Server 2012 R2%'
In a nutshell I’ll provide some easy to us WMI filter examples:
# Windows Server 2012 en 2016 by Name Select Name From Win32_OperatingSystem Where Name like '%Windows Server 2012 R2%' Or Name Like '%Windows Server 2016%'
# Windows Server 2016 by Version Select Version From Win32_OperatingSystem Where Version Like "10.0.14%"
Why did I use “Like “10.0.14%”“? Simply because Windows Server 2019’s version number also starts with 10.0. So by not adding .14 I’d also match Windows Server 2019:
# Windows Server 2016 en 2019 by Version Select Version From Win32_OperatingSystem Where Version Like "10.0%"
And finally to only target Windows Server 2019:
# Windows Server 2019 by Version Select Version From Win32_OperatingSystem Where Version Like "10.0.17%"
Want to match Windows Server 2022 in a GPO WMI Filter, so you can enable HTTP/3 in Windows Server 2022 only, use the following WQL (WMI Query):
# Windows Server 2022 by Version SELECT Version FROM Win32_OperatingSystem WHERE Version LIKE "10.0.20%"
In PowerShell, this gives you
Get-CimInstance -Namespace root\cimv2 -Query "SELECT Version FROM Win32_OperatingSystem WHERE Version LIKE '10.0.20%'" | Select Version Version ------- 10.0.20348
Match computer name in GPO WMI Filter
If you need to match a computer name in your GPO WMI Filter, you can use the following:
Select Name From Win32_ComputerSystem Where Name = "server name"
Using this, an GPO is only applied if the computer -or server- name matches. Otherwise it is filtered out.
Not Like WMI Query
If you want to filter out one or two specific hosts, you can negate your query by using NOT LIKE in a WMI query. The syntax is very confusing and not intuitive. Here is how to do a WMI query for items that are NOT what you want:
Get-CimInstance -Namespace root\cimv2 -Query "SELECT Name FROM Win32_ComputerSystem WHERE NOT (Name LIKE 'host-a%') and NOT (Name like 'host-b%')" | Select-Object Name
Get-WmiObject deprecated in PowerShell 6.2 and up
Note: in PowerShell 6.2 and up, the WMI v1 cmdlets, like
Get-WmiObject, are deprecated. See Breaking Changes for PowerShell 6.x. You now have to use CIM (aka WIM v2), like for example
PS C:\> Get-CimInstance -Class Win32_OperatingSystem | Select Version, ProductType Version ProductType ------- ----------- 10.0.17763 3
WMI Filters conclusion
Using WMI filters like these in Group Policy Management Console, you can fine-tune your GPO targetting. It is a powerful tool in your automation. If needed, you can even query the hardware manufacturer in your script:
(Get-CimInstance -ClassName Win32_ComputerSystem).Manufacturer