Freigeben über


So entfernen Sie alte Produktconnectors aus Operations Manager

In diesem Artikel wird beschrieben, wie Sie einen alten Produktconnector mithilfe eines PowerShell-Skripts aus System Center Operations Manager entfernen.

Ursprüngliche Produktversion: System Center Operations Manager
Ursprüngliche KB-Nummer: 2626670

Zusammenfassung

Das Entfernen eines alten Produktconnectors aus System Center Operations Manager kann erforderlich sein, wenn der Produktconnector nicht mehr in der Umgebung verwendet wird. Auf der Verwaltungskonsolen-Benutzeroberfläche für Produktconnectors gibt es keine Option zum Löschen , sodass das Skript verwendet werden kann, um die gewünschten Ergebnisse zu erzielen.

PowerShell-Skript

Verwenden Sie das folgende PowerShell-Skript, um den Produktconnector zu entfernen:

Notiz

Interne Connectors sollten nicht entfernt werden. Stellen Sie außerdem sicher, dass Sie sowohl die Operative Datenbank als auch die Data Warehouse-Datenbank sichern, bevor Sie dies ausführen. Speichern Sie auch die folgenden Skripts als DeleteConnector.ps1.

param(
    [String] $connectorName,
    [String] $mgName="localhost"
)

add-pssnapin Microsoft.EnterpriseManagement.OperationsManager.Client
$installDirPS = (get-itemproperty -path 'hklm:\SOFTWARE\Microsoft\Microsoft Operations Manager\3.0\Setup' -name InstallDirectory).InstallDirectory
set-location $installDirPS
Microsoft.EnterpriseManagement.OperationsManager.ClientShell.Startup.ps1

$mg = new-object Microsoft.EnterpriseManagement.ManagementGroup $mgName
$admin = $mg.GetConnectorFrameworkAdministration()

##########################################################################################
# Configures a connector with the specified name.
##########################################################################################
function New-Connector([String] $name)
{
    $connectorForTest = $null;
    foreach($connector in $admin.GetMonitoringConnectors())
    {
     if($connector.Name -eq ${name})
     {
      $connectorForTest = Get-Connector -id $connector.id
     }
    }

    if ($connectorForTest -eq $null)
    {
        $testConnector = New-Object Microsoft.EnterpriseManagement.ConnectorFramework.ConnectorInfo
        $testConnector.Name = $name
        $testConnector.Description = "${name} Description"
        $testConnector.DiscoveryDataIsManaged = $false
        $connectorForTest = $admin.Setup($testConnector)
        $connectorForTest.Initialize();
    }
    return $connectorForTest
}


##########################################################################################
# Removes a connector with the specified name.
##########################################################################################
function Remove-Connector([String] $name)
{
    $testConnector = $null
    foreach($connector in $admin.GetMonitoringConnectors())
    {
     if($connector.Name -eq ${name})
     {
      $testConnector = Get-Connector -id $connector.id
     }
    }
    if ($testConnector -ne $null)
    {
    if($testConnector.Initialized)
    {
    foreach($alert in $testConnector.GetMonitoringAlerts())
    {
     $alert.ConnectorId = $null;
     $alert.Update("Delete Connector");
    }
    $testConnector.Uninitialize()
    }
    $connectorIdForTest = $admin.Cleanup($testConnector)
    }
}

##########################################################################################
# Delete a connector's Subscription
##########################################################################################
function Delete-Subscription([String] $name)
{
 foreach($testconnector in $admin.GetMonitoringConnectors())
 {
   if($testconnector.Name -eq $name)
   {
     $connector = Get-Connector -id $testconnector.id
   }
 }
 $subs = $admin.GetConnectorSubscriptions()
 foreach($sub in $subs)
 {
  if($sub.MonitoringConnectorId -eq $connector.id)
  {
   $admin.DeleteConnectorSubscription($admin.GetConnectorSubscription($sub.Id))
  }
 }
}

#New-Connector $connectorName
write-host "Delete-Subscription"
Delete-Subscription $connectorName
write-host "Remove-Connector"
Remove-Connector $connectorName

Weitere Informationen

Verwendung: DeleteConnector.ps1 para1 para2

Para1: Connectorname

Para2: Verwaltungsservername, Optional, Standardwert: localhost

Wenn Sie versuchen, den internen Operations Manager-Connector aus der Datenbank zu löschen, wird der folgende Fehler generiert:

Ausnahmeinhalt:

Ausnahme beim Aufrufen von "Setup" mit "1"-Argumenten: "Ermittlungsdaten, die durch ungültigen Connector generiert wurden:7431E155-3D9E-4724-895E-C03BA951A352."