2020-08-27 00:37:32 -07:00
package metrics
import (
log "github.com/sirupsen/logrus"
)
2020-12-07 13:44:41 -08:00
const maxCPUAlertingThresholdPCT = 80
const maxRAMAlertingThresholdPCT = 80
const maxDiskAlertingThresholdPCT = 90
2020-08-27 00:37:32 -07:00
2020-10-02 12:18:08 -07:00
const alertingError = "The %s utilization of %d%% can cause issues with video generation and delivery. Please visit the documentation at http://owncast.online/docs/troubleshooting/ to help troubleshoot this issue."
2020-08-27 00:37:32 -07:00
func handleAlerting ( ) {
handleCPUAlerting ( )
handleRAMAlerting ( )
2020-10-02 12:18:08 -07:00
handleDiskAlerting ( )
2020-08-27 00:37:32 -07:00
}
func handleCPUAlerting ( ) {
if len ( Metrics . CPUUtilizations ) < 2 {
return
}
avg := recentAverage ( Metrics . CPUUtilizations )
if avg > maxCPUAlertingThresholdPCT {
2021-01-21 23:14:52 +01:00
log . Warnf ( alertingError , "CPU" , maxCPUAlertingThresholdPCT )
2020-08-27 00:37:32 -07:00
}
}
func handleRAMAlerting ( ) {
if len ( Metrics . RAMUtilizations ) < 2 {
return
}
avg := recentAverage ( Metrics . RAMUtilizations )
if avg > maxRAMAlertingThresholdPCT {
2021-01-21 23:14:52 +01:00
log . Warnf ( alertingError , "memory" , maxRAMAlertingThresholdPCT )
2020-10-02 12:18:08 -07:00
}
}
func handleDiskAlerting ( ) {
if len ( Metrics . DiskUtilizations ) < 2 {
return
}
avg := recentAverage ( Metrics . DiskUtilizations )
if avg > maxDiskAlertingThresholdPCT {
2021-01-21 23:14:52 +01:00
log . Warnf ( alertingError , "disk" , maxRAMAlertingThresholdPCT )
2020-08-27 00:37:32 -07:00
}
}
2020-10-02 00:06:14 -07:00
func recentAverage ( values [ ] timestampedValue ) int {
2020-11-14 18:39:53 -08:00
return ( values [ len ( values ) - 1 ] . Value + values [ len ( values ) - 2 ] . Value ) / 2
2020-08-27 00:37:32 -07:00
}