feat: 面板重启导致计划任务失败时进行短信告警 (#6817)

This commit is contained in:
2024-10-23 11:46:19 +08:00 committed by GitHub
parent 7faef2f8a7
commit 123997fa13
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -7,6 +7,7 @@ import (
"path" "path"
"strings" "strings"
"github.com/1Panel-dev/1Panel/backend/app/dto"
"github.com/1Panel-dev/1Panel/backend/app/model" "github.com/1Panel-dev/1Panel/backend/app/model"
"github.com/1Panel-dev/1Panel/backend/app/repo" "github.com/1Panel-dev/1Panel/backend/app/repo"
"github.com/1Panel-dev/1Panel/backend/constant" "github.com/1Panel-dev/1Panel/backend/constant"
@ -14,6 +15,7 @@ import (
"github.com/1Panel-dev/1Panel/backend/utils/cmd" "github.com/1Panel-dev/1Panel/backend/utils/cmd"
"github.com/1Panel-dev/1Panel/backend/utils/common" "github.com/1Panel-dev/1Panel/backend/utils/common"
"github.com/1Panel-dev/1Panel/backend/utils/encrypt" "github.com/1Panel-dev/1Panel/backend/utils/encrypt"
"github.com/1Panel-dev/1Panel/backend/utils/xpack"
) )
func Init() { func Init() {
@ -126,11 +128,24 @@ func handleSnapStatus() {
} }
func handleCronjobStatus() { func handleCronjobStatus() {
_ = global.DB.Model(&model.JobRecords{}).Where("status = ?", constant.StatusWaiting). var jobRecords []model.JobRecords
Updates(map[string]interface{}{ _ = global.DB.Where("status = ?", constant.StatusWaiting).Find(&jobRecords).Error
"status": constant.StatusFailed, for _, record := range jobRecords {
"message": "the task was interrupted due to the restart of the 1panel service", err := global.DB.Model(&model.JobRecords{}).Where("status = ?", constant.StatusWaiting).
}).Error Updates(map[string]interface{}{
"status": constant.StatusFailed,
"message": "the task was interrupted due to the restart of the 1panel service",
}).Error
if err != nil {
global.LOG.Errorf("Failed to update job ID: %v, Error:%v", record.ID, err)
continue
}
var cronjob *model.Cronjob
_ = global.DB.Where("id = ?", record.CronjobID).First(&cronjob).Error
handleCronJobAlert(cronjob)
}
} }
func loadLocalDir() { func loadLocalDir() {
@ -210,3 +225,17 @@ func initDir() {
} }
} }
} }
func handleCronJobAlert(cronjob *model.Cronjob) {
pushAlert := dto.PushAlert{
TaskName: cronjob.Name,
AlertType: cronjob.Type,
EntryID: cronjob.ID,
Param: cronjob.Type,
}
err := xpack.PushAlert(pushAlert)
if err != nil {
global.LOG.Errorf("cronjob alert push failed, err: %v", err)
return
}
}