2020-08-27 00:37:32 -07:00
package metrics
import (
log "github.com/sirupsen/logrus"
)
const maxCPUAlertingThresholdPCT = 95
const maxRAMAlertingThresholdPCT = 95
2020-08-27 00:49:01 -07:00
const alertingError = "The %s utilization of %d%% is higher than the alerting threshold of %d%%. This 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 ( )
}
func handleCPUAlerting ( ) {
if len ( Metrics . CPUUtilizations ) < 2 {
return
}
avg := recentAverage ( Metrics . CPUUtilizations )
if avg > maxCPUAlertingThresholdPCT {
log . Errorf ( alertingError , "CPU" , avg , maxCPUAlertingThresholdPCT )
}
}
func handleRAMAlerting ( ) {
if len ( Metrics . RAMUtilizations ) < 2 {
return
}
avg := recentAverage ( Metrics . RAMUtilizations )
if avg > maxRAMAlertingThresholdPCT {
log . Errorf ( alertingError , "memory" , avg , maxRAMAlertingThresholdPCT )
}
}
2020-10-02 00:06:14 -07:00
func recentAverage ( values [ ] timestampedValue ) int {
2020-08-27 00:37:32 -07:00
return int ( ( values [ len ( values ) - 1 ] . Value + values [ len ( values ) - 2 ] . Value ) / 2 )
}