You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1015 B
40 lines
1015 B
2 years ago
|
package tools
|
||
|
|
||
|
import (
|
||
|
"OpenIM/pkg/common/config"
|
||
|
"OpenIM/pkg/common/log"
|
||
|
"OpenIM/pkg/common/tracelog"
|
||
|
"OpenIM/pkg/utils"
|
||
|
"context"
|
||
|
"fmt"
|
||
|
"github.com/robfig/cron/v3"
|
||
|
"sync"
|
||
|
)
|
||
|
|
||
|
const cronTaskOperationID = "cronTaskOperationID-"
|
||
|
const moduleName = "cron"
|
||
|
|
||
|
func StartCronTask() error {
|
||
|
log.NewPrivateLog(moduleName)
|
||
|
log.NewInfo(utils.OperationIDGenerator(), "start cron task", "cron config", config.Config.Mongo.ChatRecordsClearTime)
|
||
|
fmt.Println("cron task start, config", config.Config.Mongo.ChatRecordsClearTime)
|
||
|
msgTool, err := InitMsgTool()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
ctx := context.Background()
|
||
|
operationID := msgTool.getCronTaskOperationID()
|
||
|
tracelog.SetOperationID(ctx, operationID)
|
||
|
c := cron.New()
|
||
|
var wg sync.WaitGroup
|
||
|
wg.Add(1)
|
||
|
_, err = c.AddFunc(config.Config.Mongo.ChatRecordsClearTime, msgTool.AllUserClearMsgAndFixSeq)
|
||
|
if err != nil {
|
||
|
fmt.Println("start cron failed", err.Error(), config.Config.Mongo.ChatRecordsClearTime)
|
||
|
return err
|
||
|
}
|
||
|
c.Start()
|
||
|
wg.Wait()
|
||
|
return nil
|
||
|
}
|