2012 DB의 트랜잭션 로그 사용 가능한 공간(\%) 모니터
SQL 2012 DB의 트랜잭션 로그 사용 가능한 공간(%) 모니터
모든 로그 파일에서 사용 가능한 공간이 부족하면 비정상 상태가 유발됩니다. 부족한 사용 가능 공간은 다음과 같은 요인으로 인해 발생할 수 있습니다.
부적합한 파일 구성 설정(크기, 최대 크기, 자동 증가 등)
미디어의 여유 공간 부족
주기적인 정기 백업 미실시
잘리지 않는 로그
이 모니터에 대한 “디스크 공간 포함” 설정은 해당 파일을 증가시킬 것으로 예상되는 작업에 대해 FALSE로 설정되어 있습니다.
다음 링크를 통해 성능 데이터를 확인합니다.
데이터베이스 성능 데이터
이 모니터는 다음과 같은 각 파일의 구성에 따라 데이터베이스 내의 각 로그 파일에 사용할 수 있는 공간을 집계합니다.
자동 증가 없음
자동 증가가 없는 파일의 경우 사용 가능한 공간은 파일의 초기 크기와 사용 중인 공간의 차이가 됩니다.
자동 증가 설정
파일 크기와 사용 중인 공간의 차이 이외에도 자동 증가가 설정된 파일에 사용할 수 있는 공간은 최대 크기와 파일 크기의 차이 또는 최대 크기와 디스크에 남아 있는 사용 가능한 공간의 차이 중 최소값이 됩니다.
자동 증가가 설정된 데이터베이스 로그 파일에 사용 가능한 공간이 부족한 것은 파일이 호스팅 논리 드라이브의 제한에 도달하고 있음을 의미할 수 있습니다. 또한 최대 크기와 자동 증가가 함께 설정된 파일의 경우 부족한 사용 가능 공간은 파일이 파일에 대해 지정된 최대 크기에 도달하고 있는 것일 수 있습니다.
사용 가능한 공간을 계산할 때는 파일의 증가량이 디스크에 남아 있는 양보다 큰 경우 파일이 증가할 수 없으며 최대 크기와 현재 파일 크기의 차이가 증가량보다 작은 경우 파일이 증가할 수 없다는 사실도 고려합니다. 이러한 경우 더 이상 증가할 수 없으므로 디스크에 남아 있는 사용 가능한 공간은 사용 가능한 공간의 일부분으로 포함되지 않습니다.
이 문제는 다음을 수행하여 해결할 수 있습니다.
자동 증가가 설정되지 않은 경우 로그 파일의 할당된 크기 증가
자동 증가가 설정된 경우 로그 파일의 최대 크기 값 증가
하나 이상의 파일에 대한 자동 증가 설정
증가 공간이 제한된 경우 사용 가능한 공간이 더 많은 다른 드라이브로 로그 파일 이동
FULL 및 BULK-LOGGED 복구 모드에 대한 로그 파일의 정기 백업 수행
로그가 잘리지 않는 다음과 같은 이유를 조사합니다.
장기 실행 중인 열려 있는 활성 트랜잭션
장기 실행 백업 작업
오랜 기간 동안 열려 있는 복제된 트랜잭션(트랜잭션 복제)
주 서버보다 오래된 미러(데이터베이스 미러링)
이 모니터에 대한 “디스크 공간 포함” 설정을 해당 파일을 증가시킬 것으로 예상되는 작업에 대해 TRUE로 설정합니다.
이 모니터가 작업에 알맞도록 임계값 수정
또는 데이터베이스에서 로그 파일의 사용 가능한 공간이 별로 중요하지 않을 경우 다음을 수행합니다.
이 특정 데이터베이스 또는 모든 데이터베이스에 대해 이 모니터 비활성화
SQL Server 온라인 설명서 참조: 파일 및 파일 그룹 아키텍처
이름 | 설명 | 기본값 |
알림 우선 순위 | 알림 우선 순위를 정의합니다. | 보통 |
알림 심각도 | 알림 심각도를 정의합니다. | 오류 |
사용 | 워크플로를 사용하거나 사용하지 않도록 설정합니다. | 아니요 |
알림 생성 | 워크플로가 알림을 생성하는지를 정의합니다. | 예 |
간격(초) | 워크플로를 실행하는 반복 시간 간격(초)입니다. | 900 |
임계값 | 임계값 변경 | 10 |
제한 시간(초) | 워크플로가 닫히고 실패한 항목으로 표시될 때까지 실행이 허용되는 시간을 지정합니다. | 300 |
Target | Microsoft.SQLServer.2012.Database | ||
Parent Monitor | Microsoft.SQLServer.2012.Database.DBSpaceMonitor | ||
Category | PerformanceHealth | ||
Enabled | False | ||
Alert Generate | True | ||
Alert Severity | Error | ||
Alert Priority | Normal | ||
Alert Auto Resolve | True | ||
Monitor Type | Microsoft.SQLServer.2012.Database.TransactionLogSpaceFreePercent.MonitorType | ||
Remotable | True | ||
Accessibility | Public | ||
Alert Message |
| ||
RunAs | Default |
<UnitMonitor ID="Microsoft.SQLServer.2012.Database.TransactionLogSpaceFreePercentMonitor" Accessibility="Public" Enabled="false" Target="SQL2012Core!Microsoft.SQLServer.2012.Database" ParentMonitorID="Microsoft.SQLServer.2012.Database.DBSpaceMonitor" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2012.Database.TransactionLogSpaceFreePercent.MonitorType" ConfirmDelivery="false">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2012.Database.TransactionLogSpaceFreePercentMonitor.AlertMessage">
<AlertOnState>Error</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>Error</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Target/Property[Type="SQL!Microsoft.SQLServer.Database"]/DatabaseName$</AlertParameter1>
<AlertParameter2>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</AlertParameter2>
<AlertParameter3>$Target/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</AlertParameter3>
<AlertParameter4>$Data/Context/Property[@Name='DBLogFreeSpaceMB']$</AlertParameter4>
<AlertParameter5>$Data/Context/Property[@Name='DBLogFreeSpacePercent']$</AlertParameter5>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState ID="Normal" MonitorTypeStateID="Normal" HealthState="Success"/>
<OperationalState ID="Error" MonitorTypeStateID="Error" HealthState="Error"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>900</IntervalSeconds>
<TimeoutSeconds>300</TimeoutSeconds>
<Threshold>10</Threshold>
<ConnectionString>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ConnectionString$</ConnectionString>
<ServerName>$Target/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ServerName>
<SqlInstanceName>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</SqlInstanceName>
<DatabaseName>$Target/Property[Type="SQL!Microsoft.SQLServer.Database"]/DatabaseName$</DatabaseName>
</Configuration>
</UnitMonitor>