mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2024-11-15 12:12:58 +08:00
feat: 面板重启导致计划任务失败时进行短信告警 (#6817)
This commit is contained in:
parent
7faef2f8a7
commit
123997fa13
1 changed files with 34 additions and 5 deletions
|
@ -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
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue