73 lines
1.6 KiB
Go
73 lines
1.6 KiB
Go
package service
|
|
|
|
import (
|
|
"runtime"
|
|
"time"
|
|
|
|
"sandc/app/eonline/internal/biz"
|
|
|
|
"github.com/go-kratos/kratos/v2/log"
|
|
)
|
|
|
|
var (
|
|
timeoutTimerPer10Second int64
|
|
timer10second *time.Timer
|
|
timer10mintus *time.Timer
|
|
)
|
|
|
|
func InitTimer() {
|
|
onTimerPer10Second()
|
|
onTimerPer10Minute()
|
|
}
|
|
|
|
func onTimerPer10Second() {
|
|
const duration = 10 * time.Second
|
|
timer10second = time.AfterFunc(duration, func() {
|
|
defer func() {
|
|
if r := recover(); r != nil {
|
|
buf := make([]byte, 4096)
|
|
l := runtime.Stack(buf, false)
|
|
log.Infof("onTimerPer10Second error: %v: %s", r, buf[:l])
|
|
}
|
|
}()
|
|
defer onTimerPer10Second()
|
|
|
|
begin := time.Now().UnixNano()
|
|
|
|
onBreatheFenHong()
|
|
|
|
end := time.Now().UnixNano()
|
|
delta := end - begin
|
|
if delta > timeoutTimerPer10Second {
|
|
log.Infof("onTimerPer10Second: begin[%dns] end[%dns], spend[%dms %dns] > [%dns]", begin, end, delta/biz.NS2MS, delta%biz.NS2MS, timeoutTimerPer10Second)
|
|
}
|
|
})
|
|
}
|
|
|
|
func onTimerPer10Minute() {
|
|
const duration = 10*time.Minute + 1*time.Second
|
|
timer10mintus = time.AfterFunc(duration, func() {
|
|
defer func() {
|
|
if r := recover(); r != nil {
|
|
buf := make([]byte, 4096)
|
|
l := runtime.Stack(buf, false)
|
|
log.Infof("onTimerPer10Minute error: %v: %s", r, buf[:l])
|
|
}
|
|
}()
|
|
defer onTimerPer10Minute()
|
|
|
|
begin := time.Now().UnixNano()
|
|
|
|
biz.SaveSvrDataOnTimer()
|
|
|
|
end := time.Now().UnixNano()
|
|
delta := end - begin
|
|
log.Infof("onTimerPer10Minute: begin[%dns] end[%dns], spend[%dms %dns]", begin, end, delta/biz.NS2MS, delta%biz.NS2MS)
|
|
})
|
|
}
|
|
|
|
func OnDestroyTimer() {
|
|
timer10second.Stop()
|
|
timer10mintus.Stop()
|
|
}
|