hi-server/scheduler/scheduler.go
shanshanzhong c582087c0f refactor: 更新项目引用路径从perfect-panel/ppanel-server到perfect-panel/server
feat: 添加版本和构建时间变量
fix: 修正短信队列类型注释错误
style: 清理未使用的代码和测试文件
docs: 更新安装文档中的下载链接
chore: 迁移数据库脚本添加日志和订阅配置
2025-10-13 01:33:03 -07:00

68 lines
2.0 KiB
Go

package scheduler
import (
"time"
"github.com/perfect-panel/server/pkg/logger"
"github.com/hibiken/asynq"
"github.com/perfect-panel/server/internal/svc"
"github.com/perfect-panel/server/queue/types"
)
type Service struct {
svc *svc.ServiceContext
server *asynq.Scheduler
}
func NewService(svc *svc.ServiceContext) *Service {
return &Service{
svc: svc,
server: initService(svc),
}
}
func (m *Service) Start() {
logger.Infof("start scheduler service")
// schedule check subscription task: every 60 seconds
checkTask := asynq.NewTask(types.SchedulerCheckSubscription, nil)
if _, err := m.server.Register("@every 60s", checkTask); err != nil {
logger.Errorf("register check subscription task failed: %s", err.Error())
}
//// schedule total server data task: every 5 minutes
//totalServerDataTask := asynq.NewTask(types.SchedulerTotalServerData, nil)
//if _, err := m.server.Register("@every 180s", totalServerDataTask); err != nil {
// logger.Errorf("register total server data task failed: %s", err.Error())
//}
// schedule reset traffic task: every day at 00:30
resetTrafficTask := asynq.NewTask(types.SchedulerResetTraffic, nil)
if _, err := m.server.Register("30 0 * * *", resetTrafficTask); err != nil {
logger.Errorf("register reset traffic task failed: %s", err.Error())
}
// schedule traffic stat task: every day at 00:00
trafficStatTask := asynq.NewTask(types.SchedulerTrafficStat, nil)
if _, err := m.server.Register("0 0 * * *", trafficStatTask, asynq.MaxRetry(3)); err != nil {
logger.Errorf("register traffic stat task failed: %s", err.Error())
}
if err := m.server.Run(); err != nil {
logger.Errorf("run scheduler failed: %s", err.Error())
}
}
func (m *Service) Stop() {
logger.Info("stop scheduler service")
m.server.Shutdown()
}
func initService(svc *svc.ServiceContext) *asynq.Scheduler {
location, _ := time.LoadLocation("Asia/Shanghai")
return asynq.NewScheduler(
asynq.RedisClientOpt{Addr: svc.Config.Redis.Host, Password: svc.Config.Redis.Pass, DB: 5},
&asynq.SchedulerOpts{
Location: location,
},
)
}