Description
Provides overall server status counts for approved Microsoft updates on a Windows Server Update Services (WSUS) server, similar to information shown at the “Update Services” node of the WSUS console for a specific server. The WSUS 3.0 console shows information for all updates, whereas this output is filtered specifically by approved Microsoft updates using an UpdateScope. This script was contributed by the Microsoft WSUS team.
The output is comma delimited text:
ServerName,CurrentDate,TotalComputers,TotalUpdates,ComputerTargetsUpToDate,ComputerTargetsNeedingUpdates,
ComputerTargetsWithErrors,UpdatesUpToDate,UpdatesNeededByComputers,UpdatesWithClientErrors
Sample output:
MYSERVER,4/5/2007,131,1527,5,64,6,0,128,9
This script connects to a WSUS 3.0 server on the machine where the script runs. This script can be adapted to connect to remote WSUS 3.0 servers by changing the GetUpdateServer() call to GetUpdateServer(<servername>, true|false), where <servername> is the name of the remote WSUS server, and true|false refers to the use of SSL to make the connection.
Supported Platforms
Windows Server 2008 | Yes |
Windows Vista | Yes |
Windows Server 2003 | Yes |
Windows XP | Yes |
Windows 2000 | No |
Windows NT 4.0 | No |
Windows 98 | No |
Script Code
[reflection.assembly]::LoadWithPartialName("Microsoft.UpdateServices.Administration") | out-null
$wsus = [Microsoft.UpdateServices.Administration.AdminProxy]::GetUpdateServer();
$updateScope = new-object Microsoft.UpdateServices.Administration.UpdateScope;
$updateScope.ApprovedStates = [Microsoft.UpdateServices.Administration.ApprovedStates]::LatestRevisionApproved;
$updateScope.UpdateSources = [Microsoft.UpdateServices.Administration.UpdateSources]::MicrosoftUpdate;
$computerScope = new-object Microsoft.UpdateServices.Administration.ComputerTargetScope;
$updatesFailed = $updatesNeeded = $updatesUpToDate = 0;
$updates = $wsus.GetSummariesPerUpdate($updateScope, $computerScope);
$updates | foreach-object {
if ($_.FailedCount) {
$updatesFailed++;
}
elseif ($_.DownloadedCount -or $_.InstalledPendingRebootCount -or $_.NotInstalledCount) {
$updatesNeeded++;
}
elseif (!$_.UnknownCount) {
$updatesUpToDate++;
}
}
$computersFailed = $computersNeeded = $computersUpToDate = 0;
$computers = $wsus.GetSummariesPerComputerTarget($updateScope, $computerScope);
$computers | foreach-object {
if ($_.FailedCount) {
$computersFailed++;
}
elseif ($_.DownloadedCount -or $_.InstalledPendingRebootCount -or $_.NotInstalledCount) {
$computersNeeded++;
}
elseif (!$_.UnknownCount) {
$computersUpToDate++;
}
}
$wsus.ServerName+","+[DateTime]::UtcNow.ToShortDateString()+","+
$computers.Count+","+$updates.Count+","+
$computersUpToDate+","+$computersNeeded+","+$computersFailed+","+
$updatesUpToDate+","+$updatesNeeded+","+$updatesFailed;
For online peer support, join the microsoft.public.windows.server.scripting community on the msnews.microsoft.com news server. To provide feedback or report bugs in sample scripts or the Scripting Guide, please contact Microsoft TechNet.
Disclaimer
The sample scripts are not supported under any Microsoft standard support program or service. The sample scripts are provided AS IS without warranty of any kind. Microsoft further disclaims all implied warranties including, without limitation, any implied warranties of merchantability or of fitness for a particular purpose. The entire risk arising out of the use or performance of the sample scripts and documentation remains with you. In no event shall Microsoft, its authors, or anyone else involved in the creation, production, or delivery of the scripts be liable for any damages whatsoever (including, without limitation, damages for loss of business profits, business interruption, loss of business information, or other pecuniary loss) arising out of the use of or inability to use the sample scripts or documentation, even if Microsoft has been advised of the possibility of such damages.