모니터에서 생성된 경고 닫기
모니터는 개체의 상태를 정의합니다. 개체는 녹색(성공 또는 정상), 노란색(경고) 또는 빨간색(위험 또는 비정상)의 세 가지 상태 중 하나를 가질 수 있습니다. 예를 들어, 디스크 드라이브 용량에 대한 모니터는 녹색을 85% 미만으로 가득 찬 상태, 노랑을 85% 이상으로 가득 찬 상태, 빨강을 90% 이상 가득 찬 상태로 정의합니다. 상태 변화가 일어날 때 모니터에서 경고를 생성하도록 구성할 수 있습니다.
경고가 수신되면 경고가 규칙 또는 모니터에 의해 생성되었는지 여부를 경고 세부 정보에서 확인할 수 있습니다. 모니터에 의해 경고가 생성된 경우 모범 사례로, 상태 상태가 정상으로 돌아올 때 모니터가 경고를 자동으로 해결하도록 허용해야 합니다. 개체가 경고 또는 비정상 상태인 동안 경고를 닫으면 문제가 해결되지 않은 상태로 유지되지만 추가 경고는 생성되지 않습니다.
상태가 빨간색으로 변경되고 경고를 해결할 때 모니터가 경고를 생성하는 경우 모니터의 상태도 다시 설정해야 합니다. 모니터가 다시 설정되지 않으면 경고를 생성한 것과 동일한 조건이 다시 발생할 수 있지만 상태가 변경되지 않았기 때문에 경고가 생성되지 않습니다.
2019년 이전의 Operations Manager에서 개체가 경고 또는 비정상 상태인 동안 경고를 닫으면 문제가 해결되지 않은 상태로 유지되지만 추가 경고는 생성되지 않습니다. 기본 문제가 있는 동안 시스템에 활성 경고가 없는 시나리오를 자주 발생시키는 이 동작은 Operations Manager 2019에서 해결되었습니다.
Operations Manager 2019를 사용하면 해당 모니터의 상태가 정상 상태가 아닌 한 모니터에서 생성된 경고를 닫을 수 없습니다. 비정상 모니터에서 생성된 경고를 닫으려고 하면 오류 메시지가 나타나고 경고가 닫혀 있지 않습니다.
운영 콘솔과 웹 콘솔 모두에서 이 새로운 동작을 확인할 수 있습니다.
운영 콘솔
다음 단계를 수행합니다.
Operations Manager 콘솔을 열고 모니터링을 선택합니다 .
모니터링 개요 는 모니터의 상태 및 현재 경고에 대한 요약을 표시합니다.
탐색 창에서 활성 경고를 선택합니다.
비정상 상태의 모니터에서 생성되는 경고를 마우스 오른쪽 단추로 클릭합니다.
해결 상태를 Closed로 설정합니다.
다음 메시지는 경고가 닫힌 이유를 나타내는 것으로 보입니다.
이러한 경고를 생성한 모니터가 여전히 비정상이므로 현재 선택 영역의 경고를 닫을 수 없습니다. 닫을 수 없는 경고에 대한 자세한 내용은 Operations Manager 웹 콘솔에서 "경고 종료 실패" 대시보드를 참조하세요.
참고 항목
이 경고를 닫기 위해 해당 모니터의 상태를 수동으로 정상 상태로 다시 설정해야 합니다. 이 모니터에 대한 자동 해제가 true로 설정된 경우 상태가 다시 설정된 후 경고가 자동으로 닫힙니다. 그렇지 않으면 상태가 다시 설정되면 경고를 수동으로 닫아야 합니다.
웹 콘솔
웹 콘솔을 열고 모니터링을 선택합니다. 모니터링 개요 는 모니터의 상태 및 현재 경고에 대한 요약을 표시합니다.
탐색 창에서 활성 경고를 선택합니다.
비정상 상태의 모니터에 의해 생성된 경고를 엽니다.
해결 상태를 닫힘 및 저장 변경 내용으로 설정합니다.
다음 메시지는 경고가 닫힌 이유를 나타내는 것으로 보입니다.
이 경고를 생성한 모니터가 여전히 비정상이므로 현재 경고를 닫을 수 없습니다.
참고 항목
이 경고를 닫려면 이 경고를 생성한 해당 모니터의 상태를 수동으로 다시 설정해야 합니다.
해당 경고에 대한 모니터의 상태를 수동으로 다시 설정
다음 단계를 수행합니다.
탐색 창에서 경고 닫기 실패 대시보드를 선택합니다. 대시보드에는 경고를 생성한 모니터가 비정상이므로 Operations Manager에서 닫을 수 없었던 경고가 나열됩니다.
다음 두 가지 방법으로 해당 경고에 대한 모니터의 상태를 다시 설정할 수 있습니다.
- 대시보드에서 경고를 선택한 다음, 경고에 대한 상태 재설정 대시보드 작업을 선택합니다. 또는
- 이 대시보드에서 경고를 선택하여 경고 드릴다운 페이지(경고에 대한 모든 관련 정보를 시각화할 수 있음)로 이동하고 작업창에서 상태 다시 설정 작업을 선택합니다.
경고 업데이트 API
인시던트 관리와 같은 외부 시스템에서 경고 폐쇄가 트리거되고 해당 모니터가 비정상 상태이기 때문에 경고가 닫혀 있지 않은 경우 외부 시스템에서 사용할 수 있는 경고 세부 정보와 함께 예외가 전달됩니다.
다음과 같은 기존 경고 업데이트 API를 사용하여 경고 업데이트 데이터를 외부화할 수 있습니다. 이러한 두 가지 API는 이 새로운 동작을 외부화할 수 있도록 향상되었습니다.
다음 샘플에서는 AlertMonitorUnhealthyException 예외를 사용하는 방법에 대한 세부 정보를 보여줍니다.
namespace MonitorAlertClosureFailureExample
{
class Program
{
static void Main(string[] args)
{
ManagementGroup mg = new ManagementGroup("localhost");
// Get database availability alerts.
MonitoringAlertCriteria alertCriteria = new MonitoringAlertCriteria(
"Name LIKE '%DBStatusMonitor' AND Category = 'AvailabilityHealth'");
IList<MonitoringAlert> alerts =
mg.OperationalData.GetMonitoringAlerts(alertCriteria, default(DateTime));
// Find the "Closed" resolution state that is defined
// for this Management Group.
IList<MonitoringAlertResolutionState> alertStates = mg.OperationalData.GetMonitoringAlertResolutionStates();
MonitoringAlertResolutionState closedState = null;
foreach (MonitoringAlertResolutionState thisState in alertStates)
{
if (thisState.Name == "Closed")
{
closedState = thisState;
}
}
// Close all alerts not already in the "Closed" resolution state.
foreach (MonitoringAlert a in alerts)
{
a.ResolutionState = closedState.ResolutionState;
string comment = "Closing the Alert";
try
{
a.Update(comment);
}
catch (AlertMonitorUnhealthyException e)
{
// It mean the alert being closed is a monitor alert and the monitor which generated this alert is still unhealthy
// take an appropriate action. Here an error message is being displayed at console
Console.WriteLine("The alert with Alert Name" + a.Name + "cannot be closed as the monitor which genrated the alert is still unhealthy.")
}
catch (Exception e)
{
// generic exception during the update of the alert
Console.WriteLine("Closing the alert with alert name" + a.Name + "is failing because" + e.Message)
}
}
}
}
namespace MonitorAlertClosureFailureExample
{
class Program
{
static void Main(string[] args)
{
ManagementGroup mg = new ManagementGroup("localhost");
// Get database availability alerts.
MonitoringAlertCriteria alertCriteria = new MonitoringAlertCriteria(
"Name LIKE '%DBStatusMonitor' AND Category = 'AvailabilityHealth'");
IList<MonitoringAlert> alerts =
mg.OperationalData.GetMonitoringAlerts(alertCriteria, default(DateTime));
// Find the "Closed" resolution state that is defined
// for this Management Group.
IList<MonitoringAlertResolutionState> alertStates = mg.OperationalData.GetMonitoringAlertResolutionStates();
MonitoringAlertResolutionState closedState = null;
foreach (MonitoringAlertResolutionState thisState in alertStates)
{
if (thisState.Name == "Closed")
{
closedState = thisState;
}
}
// Close all alerts not already in the "Closed" resolution state.
string comment = "Closing the alert";
foreach(MonitoringAlert a in alerts)
{
a.ResolutionState = closedState.ResolutionState;
}
IList<MonitoringAlertUpdateFailure> updateFailures = mg.OperationalData.UpdateMonitoringAlerts(alerts, comment);
if (updateFailures != null && updateFailures.Count > 0)
{
foreach (MonitoringAlertUpdateFailure failure in updateFailures)
{
if(failure.Exception is AlertMonitorUnhealthyException)
{
// It means the alert being closed is a monitor alert and the monitor which generated this alert is still unhealthy
// take an appropriate action. Here an error message is being displayed at console
Console.WriteLine("The alert with Alert Name" + a.Name + "cannot be closed as the monitor which genrated the alert is still unhealthy.")
}
}
}
}
}
경고가 자동으로 해결되는지 확인
다음 단계를 수행합니다.
경고를 선택한 다음 경고 세부 정보에서 경고 모니터의 이름을 선택합니다. 모니터의 속성 대화 상자가 열립니다.
모니터 속성에서 경고 탭을 선택하여 모니터가 정상 상태로 돌아올 때 경고가 자동으로 해결되는지 확인합니다.
모니터에서 생성된 경고 닫기
다음 단계를 수행합니다.
경고를 읽고 해당 속성을 검사합니다. 경고 세부 정보를 확인하여 모니터 또는 규칙에 의해 경고가 생성되었는지 확인합니다. 경고에 대한 제품 지식을 사용하여 경고의 원인을 확인할 수 있습니다.
경고의 원인을 해결하고 문제를 해결하는 데 필요한 작업을 수행합니다.
문제가 해결되면 경고 세부 정보에서 원본을 선택합니다. 그러면 경고와 연결된 개체의 상태 보기가 열립니다.
개체를 마우스 오른쪽 단추로 클릭하고 열기를 가리킨 다음 개체 이름으로 상태 탐색기를 선택합니다.
경고를 생성한 모니터를 선택하고 도구 모음에서 상태 재설정을 선택합니다. 상태 탐색기 및 상태 보기를 닫습니다.
경고 보기를 새로 고칩니다. 경고가 여전히 나열된 경우 경고를 선택하고 작업 창에서 경고 닫기를 선택합니다.
참고 항목
Operations Manager 2019 UR3 이상에서는 다음 업데이트(연결 없는 경고 종결)가 적용됩니다.
고아 경고의 폐쇄
Operations Manager 2019 RTM, UR1 및 UR2에서는 아래에 설명된 대로 특정 시나리오에서 비영구 상태 후에 활성 경고가 종료되지 않습니다.
장애 조치(failover):
- 관리 서버가 오프라인 상태가 될 때 트리거될 수 있는 장애 조치(failover)입니다.
- 리소스 풀에 새 관리 서버가 추가되어 부하 분산이 발생합니다.
- 에이전트 없는 컴퓨터가 장애 조치(fails over)되어 다른 관리 서버에서 모니터링되는 경우 새 상태가 됩니다.
에이전트 연결이 끊어지고 상태가 변경되어 이전 상태를 인식하지 못하는 시간이 지나면 다시 연결됩니다.
관리 서버의 연결이 끊어지고 다시 연결되었습니다.
상태 서비스 캐시가 지워진 경우
전반적으로 상태 서비스는 모니터의 마지막 상태를 유지하지 않습니다. 모니터를 정상 상태로 다시 설정하는 동안 경고가 닫혀 있지 않습니다.
Operations Manager 2019 UR3을 사용하면 아래 설명된 대로 모니터 유형에 따라 결국 모든 고아 경고가 닫힙니다.
- 서비스 모니터: 즉시 닫습니다.
- 즉시 주문형 모듈이 있는 모든 모니터: 즉시 닫습니다.
- 주문형 모듈이 없는 모든 모니터: 빈도에 따라 두 번째 실행 시 닫습니다.
- 이벤트 기반 모니터: 초기화 후 발생하는 정상 이벤트로 닫습니다.
상태 전환은 모니터를 초기화할 때 약간의 변경을 표시합니다. 아래 샘플:
위 그림과 같이 초기화 중에 모니터가 먼저 정상으로 바뀝니다. 그런 다음 다시 계산하고 정상으로 바뀝니다. 빈 상태에서 정상 상태로의 두 가지 상태 변경 전환이 표시됩니다.
경고 닫기 환경의 변경 내용
관리자는 비정상 상태인 상태 모니터 경고 닫기를 선택할 수 있습니다.
2019년 릴리스에서는 해당 모니터의 상태가 정상이 아닌 한 모니터에서 생성된 경고를 닫을 수 없습니다. 비정상 모니터에서 생성된 경고를 닫으려고 하면 오류 메시지가 나타나고 경고가 닫히지 않습니다.
관리자는 관리>설정으로 이동하여 다음 옵션을 선택하여 이 동작을 변경할 수 있습니다.
- 기본 모니터 상태가 해결되거나 수동으로 다시 설정될 때만 모니터에서 생성된 경고 닫기
- 기본 모니터 상태를 다시 설정하여 모니터에서 생성한 경고 닫기: 이 옵션을 사용하면 비정상 모니터의 경고를 프로그래밍 방식으로 UI에서 닫을 수 있습니다. 이렇게 하면 기본 모니터 상태가 다시 설정되어 해당 경고를 암시적으로 닫습니다. 또한 이 옵션을 사용하면 모니터에서 생성된 경고를 대량으로 닫을 수 있습니다.
경고 속성>기록을 확인하여 경고가 닫힌 방법을 추적할 수도 있습니다.
다음 단계
경고가 생성되면 작업 및 웹 콘솔에서 활성 경고 및 세부 정보를 확인하여 가능한 문제를 식별하고 해결을 위한 다음 단계를 식별할 수 있습니다.
하나 이상의 모니터에서 검색된 문제를 조사하고 해결한 후 모니터가 자동으로 해결되도록 구성되지 않았거나 모니터가 상태를 감지할 때까지 기다리지 않으려는 경우 상태를 수동으로 다시 설정하도록 상태를 다시 설정하는 방법을 검토합니다.