Monitor de Fluxo de Trabalho da Estrutura de Ligação
Normalmente, as falhas de fluxo de trabalho de tratamento podem acontecer devido a uma das seguintes razões. A vista de alertas ativos terá um alerta associado a esta falha. O reconhecimento de alerta irá indicar a causa específica da falha.
1. Falha de fluxo de trabalho de tratamento : As falhas do fluxo de trabalho indicam que o fluxo de trabalho encontrou um problema que causou a paragem de trabalho. Um fluxo de trabalho falhado implica normalmente que o problema é conhecido.
Os fluxos de trabalho podem falhar para várias razões, tais como problema de conetividade de base de dados, problemas de direitos de base de dados ou o servidor de base de dados poderá não estar a funcionar.
2. Tempo Limite para o fluxo de trabalho de tratamento : Se um fluxo de trabalho não concluir uma atividade no prazo de 25 minutos, o tempo limite será excedido. A exceção é o fluxo de trabalho do registo de subscrição de tratamento, cujo tempo limite é de 15 minutos.
Existem diversas causas para atingir o limite de tempo do fluxo de trabalho, tais como executar quando um serviço é reiniciado, uma longa fila de espera ou APIs que demoram muito tempo a serem devolvidas.
Se o fluxo de trabalho do Tratamento falhar,
Verifique o registo de eventos para obter informações detalhadas sobre a falha, bem como diretrizes para a sua resolução.
Se o fluxo de trabalho de Tratamento Exceder o Tempo Limite,
Pode ser um problema com a base de dados. Verifique o registo de eventos para obter informações detalhadas sobre a falha, bem como diretrizes para a sua resolução.
Target | Microsoft.SystemCenter.ServiceManager.SmManagementServer | ||
Parent Monitor | Microsoft.ServiceManager.Workflows.AvailabilityHealthRollup | ||
Category | StateCollection | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | Warning | ||
Alert Priority | High | ||
Alert Auto Resolve | True | ||
Monitor Type | Microsoft.SystemCenter.ServiceManager.Workflows.OLEDB.Monitoring.DBProbeMonitorType | ||
Remotable | True | ||
Accessibility | Public | ||
Alert Message |
| ||
RunAs | Default |
<UnitMonitor ID="Microsoft.SystemCenter.ServiceManager.GroomingWorkflows.Monitor" TypeID="Microsoft.SystemCenter.ServiceManager.Workflows.OLEDB.Monitoring.DBProbeMonitorType" Accessibility="Public" Target="SM!Microsoft.SystemCenter.ServiceManager.SmManagementServer" ParentMonitorID="Microsoft.ServiceManager.Workflows.AvailabilityHealthRollup">
<Category>StateCollection</Category>
<AlertSettings AlertMessage="Microsoft.ServiceManager.GroomingWorkflows.AlertMessage">
<AlertOnState>Warning</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>High</AlertPriority>
<AlertSeverity>Warning</AlertSeverity>
</AlertSettings>
<OperationalStates>
<OperationalState MonitorTypeStateID="State1" HealthState="Warning" ID="ComponentUnhealthy"/>
<OperationalState MonitorTypeStateID="State2" HealthState="Success" ID="ComponentHealthy"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>60</IntervalSeconds>
<SyncTime/>
<ConnectionString>Provider=SQLOLEDB;Server=$Target/Property[Type='SM!Microsoft.SystemCenter.ServiceManager.SmManagementServer']/SmDbHostName$;Database=$Target/Property[Type='SM!Microsoft.SystemCenter.ServiceManager.SmManagementServer']/SMDbName$;Integrated Security=SSPI</ConnectionString>
<Query>
SELECT COUNT(*)
FROM dbo.InternalJobHistory Job,
(SELECT max(timestarted) as LastTime, command
FROM dbo.InternalJobHistory
GROUP BY command) GroupJob
WHERE job.Command = GroupJob.Command
AND job.TimeStarted= GroupJob.LastTime
AND (
(job.StatusCode = '0' AND (DATEDIFF(MINUTE, job.TimeStarted , GETUTCDATE()) >= 25)) OR
(job.StatusCode = '0' AND (DATEDIFF(MINUTE, job.TimeStarted , GETUTCDATE()) >= 15) AND job.Command like '%Subscription%') OR
job.StatusCode ='2'
)
</Query>
<State1Filter>
<SimpleExpression>
<ValueExpression>
<XPathQuery Type="String">Columns/Column[1]</XPathQuery>
</ValueExpression>
<Operator>NotEqual</Operator>
<ValueExpression>
<Value Type="String">0</Value>
</ValueExpression>
</SimpleExpression>
</State1Filter>
<State2Filter>
<SimpleExpression>
<ValueExpression>
<XPathQuery Type="String">Columns/Column[1]</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value Type="String">0</Value>
</ValueExpression>
</SimpleExpression>
</State2Filter>
</Configuration>
</UnitMonitor>