- Windows Server 2016 Automation with PowerShell Cookbook(Second Edition)
- Thomas Lee
- 308字
- 2021-07-02 18:15:56
How it works...
In step 1, you create the $WSUSServer object using Get-WsusServer and use the GetStatus method to view the status of Windows updates on the WSUS server:
data:image/s3,"s3://crabby-images/0b1b3/0b1b34050f02aa5ac97d810efb80dd3c530ae05c" alt=""
In step 2, you review the computer targets configured in WSUS with the GetComputerTargets method:
data:image/s3,"s3://crabby-images/6d254/6d2544a119f048a00a0b8fada641c14d7449e55c" alt=""
In step 3, you use two different methods to view the installed updates. The first is Get-Hotfix, and the second is Get-SilWindowsUpdate, which is one of the SoftwareInventoryLogging module cmdlets introduced in PowerShell version 5. These cmdlets use CIM sessions to connect to computers and gather inventory information:
data:image/s3,"s3://crabby-images/6a849/6a84996b8e535354b63a33c506adc1f604ce1db1" alt=""
In step 4, you use the SearchUpdates method on the $WSUSServer to search the available updates by title, then use Where-Object to filter on the UpdateClassificationTitle property for security updates and then sort them from newest to oldest. You then use Get-Member to examine the Update object, noting the many methods and properties:
data:image/s3,"s3://crabby-images/b4fd2/b4fd2859bd309345d11e432b1e4dfc1b3c9e6820" alt=""
In step 5, you view the security updates that matched your search. Note that each displays a knowledge base (KB) ID that is useful for identifying and researching individual updates:
data:image/s3,"s3://crabby-images/33082/330826019b3d09668c8a8fee41e8abbafafcb858" alt=""
In step 6, you filter the selected updates for a single update that you wish to approve using Where-Object to match on the KnowledgebaseArticles property:
data:image/s3,"s3://crabby-images/5f149/5f1490db893be7eb18db442fa88cdc0ea0d15d12" alt=""
In step 7, you define the computer target group for the Domain Controllers using the GetComputerTargetGroups method of the $WSUSServer object, filtered by Where-Object:
data:image/s3,"s3://crabby-images/e5684/e568419bacbb890d393b4aeaed08d46825105dc1" alt=""
In step 8, you use the Approve method of the $SelectedUpdate object-which takes two parameters:, an UpdateApprovalAction and a TargetGroup-and approve the selected update for the Domain Controllers target group:
data:image/s3,"s3://crabby-images/f171f/f171f645701a7a1e22c48c115d17e6390b1ab135" alt=""
In step 9, you select an update to decline, using Where-Object to filter the selection to a single update using the KnowledgebaseArticles property:
data:image/s3,"s3://crabby-images/07a4e/07a4ee494398d3f5f06e8adcb5d71406419a253b" alt=""
In step 10, you use the Decline method of the update object, and provide the TargetGroup object as a parameter to decline this update for the Domain Controllers target group computers:
data:image/s3,"s3://crabby-images/022fc/022fcb953bbe31927ab854c12e8a38ec4754f0c4" alt=""