Удаление старых соединителей продуктов из Operations Manager
В этой статье описывается, как удалить старый соединитель продукта из System Center Operations Manager с помощью скрипта PowerShell.
Исходная версия продукта: System Center Operations Manager
Исходный номер базы знаний: 2626670
Итоги
Удаление старого соединителя продукта из System Center Operations Manager может потребоваться, если соединитель продукта больше не используется в среде. В пользовательском интерфейсе консоли администрирования для соединителей продуктов отсутствует параметр delete , чтобы скрипт можно было использовать для достижения требуемых результатов.
Сценарий PowerShell
Чтобы удалить соединитель продукта, используйте следующий скрипт PowerShell:
Примечание.
Внутренние соединители не следует удалять, а также резервное копирование операционной базы данных и базы данных хранилища данных перед выполнением этой операции. Кроме того, сохраните следующие скрипты как 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
Дополнительная информация
Использование: DeleteConnector.ps1 para1 para2
para1: имя соединителя
para2: имя сервера управления, необязательное значение по умолчанию: localhost
Если вы пытаетесь удалить внутренний соединитель Operations Manager из базы данных, это приведет к следующей ошибке:
Содержимое исключения:
Исключение, вызывающее "Setup" с аргументами "1": "Данные обнаружения, созданные недопустимым соединителем:7431E155-3D9E-4724-895E-C03BA951A352".