Мониторинг операционного состояния конечной веб-точки VMM Service Provider Foundation.
Мониторинг доступности и работоспособности веб-интерфейса VMM с веб-серверов Service Provider Foundation. Он выполняется с помощью периодического тестового вызова веб-интерфейса, возвращающего облачные ресурсы.
Чтобы этот монитор работал правильно, он должен иметь разрешение администратора на доступ к облачным ресурсам на серверах VMM. Создайте учетную запись запуска от имени, которая использует такие же разрешения, что и учетная запись пула приложений, указанная для конечной веб-точки VMM, и добавьте ее в профиль запуска от имени, который называется "учетная запись VMM Microsoft Service Provider Foundation".
На этом мониторе можно настроить следующие параметры:
Параметр | Определение | По умолчанию |
Предупреждение о состоянии | Состояние работоспособности монитора, которое создает предупреждение. | Монитор находится в критическом состоянии |
Приоритет предупреждения | Приоритет предупреждения, созданного для этого монитора. | Высокий |
Серьезность предупреждения | Приоритет предупреждения, созданного для этого монитора. | Критический |
Предупреждение с автоматическим разрешением | Указывает, должно ли предупреждение разрешаться автоматически при возвращении монитора в состояние "Работает". | True |
Включено | Указывает, должен ли запускаться монитор. | True |
Создает предупреждение | Указывает, должен ли монитор создать предупреждение при изменении с состояния "Предупреждение" на "Критическое". | True |
Интервал | Число секунд, в течение которых монитор отключен. | 300 |
Если на мониторе отображается ошибка, а на других мониторах подключений — нет, скорее всего, возникла ошибка конфигурации структуры или ошибка разрешений. Дополнительные сведения о настройке монитора см. в разделе "Настройка".
Проверьте конфигурацию структуры в облачных ресурсах на целевом сервере VMM и убедитесь, что учетной записи администратора предоставлены права доступа. Проверьте правильность настройки безопасности для монитора.
Target | Microsoft.SystemCenter.SPF.SpfServer | ||
Parent Monitor | System.Health.AvailabilityState | ||
Category | AvailabilityHealth | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | MatchMonitorHealth | ||
Alert Priority | Normal | ||
Alert Auto Resolve | True | ||
Monitor Type | Microsoft.SystemCenter.ServiceProviderFoundation.PowerShellModule.TwoStateMonitorType.PropertyBag | ||
Remotable | True | ||
Accessibility | Public | ||
Alert Message |
| ||
RunAs | Microsoft.SystemCenter.SPF.VmmEndpointAccount |
<UnitMonitor ID="Microsoft.SystemCenter.SPF.Monitor.VMMEndpointGet" Accessibility="Public" Enabled="true" Target="Microsoft.SystemCenter.SPF.SpfServer" ParentMonitorID="Health!System.Health.AvailabilityState" Remotable="true" Priority="Normal" TypeID="Microsoft.SystemCenter.ServiceProviderFoundation.PowerShellModule.TwoStateMonitorType.PropertyBag" ConfirmDelivery="false" RunAs="Microsoft.SystemCenter.SPF.VmmEndpointAccount">
<Category>AvailabilityHealth</Category>
<AlertSettings AlertMessage="Microsoft.SystemCenter.SPF.Monitor.VMMEndpointGet.AlertMessage">
<AlertOnState>Error</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>MatchMonitorHealth</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Data/Context/Property[@Name='StatusCode']$</AlertParameter1>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState ID="Error" MonitorTypeStateID="Error" HealthState="Error"/>
<OperationalState ID="Success" MonitorTypeStateID="Success" HealthState="Success"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>300</IntervalSeconds>
<SyncTime/>
<ScriptName>HealthOfSpfServer.ps1</ScriptName>
<ScriptBody> param
(
$PortNumber
)
$oAPI = new-object -comObject "MOM.ScriptAPI"
$propertyBag = $oAPI.CreatePropertyBag()
$errorActionSetting = $ErrorActionPreference
$downVmmServers = ""
$res = $null
try
{
$ErrorActionPreference = "Stop"
[Net.ServicePointManager]::ServerCertificateValidationCallback = {$true}
$req = [System.Net.WebRequest]::Create("https://localhost:$PortNumber/SC2012R2/VMM/Microsoft.Management.OData.svc/Clouds")
$req.UseDefaultCredentials = $true
$res = $req.GetResponse()
$int = [int]$res.StatusCode
if($int -eq 200)
{
$propertyBag.AddValue("Result", "Success")
}
else
{
$propertyBag.AddValue("Result", "Failure")
}
$propertyBag.AddValue("StatusCode", $int)
}
catch
{
$propertyBag.AddValue("Result", "Failure")
$propertyBag.AddValue("StatusCode", $_.Exception.Message)
}
finally
{
$ErrorActionPreference = $errorActionSetting
if($res -ne $null)
{
$res.Close()
}
$propertyBag
}
</ScriptBody>
<Parameters>
<Parameter>
<Name>PortNumber</Name>
<Value>$Target/Property[Type="Microsoft.SystemCenter.SPF.SpfServerBase"]/PortNumber$</Value>
</Parameter>
</Parameters>
<TimeoutSeconds>300</TimeoutSeconds>
<ErrorExpression>
<SimpleExpression>
<ValueExpression>
<XPathQuery Type="String">Property[@Name='Result']</XPathQuery>
</ValueExpression>
<Operator>NotEqual</Operator>
<ValueExpression>
<Value Type="String">Success</Value>
</ValueExpression>
</SimpleExpression>
</ErrorExpression>
<SuccessExpression>
<SimpleExpression>
<ValueExpression>
<XPathQuery Type="String">Property[@Name='Result']</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value Type="String">Success</Value>
</ValueExpression>
</SimpleExpression>
</SuccessExpression>
</Configuration>
</UnitMonitor>