Files
EdgeAPI/internal/tasks/node_task_extractor.go
2021-12-14 10:49:29 +08:00

58 lines
1.2 KiB
Go
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

package tasks
import (
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
"github.com/TeaOSLab/EdgeAPI/internal/goman"
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
"github.com/iwind/TeaGo/dbs"
"github.com/iwind/TeaGo/logs"
"time"
)
func init() {
dbs.OnReadyDone(func() {
goman.New(func() {
NewNodeTaskExtractor().Start()
})
})
}
// NodeTaskExtractor 节点任务
type NodeTaskExtractor struct {
}
func NewNodeTaskExtractor() *NodeTaskExtractor {
return &NodeTaskExtractor{}
}
func (this *NodeTaskExtractor) Start() {
ticker := time.NewTicker(10 * time.Second)
for range ticker.C {
err := this.Loop()
if err != nil {
logs.Println("[TASK][NODE_TASK_EXTRACTOR]" + err.Error())
}
}
}
func (this *NodeTaskExtractor) Loop() error {
ok, err := models.SharedSysLockerDAO.Lock(nil, "node_task_extractor", 10-1) // 假设执行时间为1秒
if err != nil {
return err
}
if !ok {
return nil
}
// 这里不解锁是为了让任务N秒钟之内只运行一次
for _, role := range []string{nodeconfigs.NodeRoleNode, nodeconfigs.NodeRoleDNS} {
err = models.SharedNodeTaskDAO.ExtractAllClusterTasks(nil, role)
if err != nil {
return err
}
}
return nil
}