优化统计性能

This commit is contained in:
刘祥超
2023-04-07 11:23:37 +08:00
parent 52085bdc1c
commit 0af580eb26
4 changed files with 49 additions and 15 deletions

View File

@@ -4,12 +4,15 @@ import (
teaconst "github.com/TeaOSLab/EdgeNode/internal/const"
"github.com/TeaOSLab/EdgeNode/internal/goman"
"github.com/iwind/TeaGo/types"
timeutil "github.com/iwind/TeaGo/utils/time"
"time"
)
var unixTime = time.Now().Unix()
var unixTimeMilli = time.Now().UnixMilli()
var unixTimeMilliString = types.String(unixTimeMilli)
var ymd = timeutil.Format("Ymd")
var round5Hi = timeutil.FormatTime("Hi", time.Now().Unix()/300*300)
func init() {
if !teaconst.IsMain {
@@ -22,6 +25,8 @@ func init() {
unixTime = time.Now().Unix()
unixTimeMilli = time.Now().UnixMilli()
unixTimeMilliString = types.String(unixTimeMilli)
ymd = timeutil.Format("Ymd")
round5Hi = timeutil.FormatTime("Hi", time.Now().Unix()/300*300)
}
})
}
@@ -66,3 +71,13 @@ func GMTTime(t time.Time) time.Time {
_, offset := time.Now().Zone()
return t.Add(-time.Duration(offset) * time.Second)
}
// Ymd 读取YYYYMMDD
func Ymd() string {
return ymd
}
// Round5Hi 读取5分钟间隔时间
func Round5Hi() string {
return round5Hi
}

View File

@@ -1,6 +1,7 @@
package utils
package utils_test
import (
"github.com/TeaOSLab/EdgeNode/internal/utils"
timeutil "github.com/iwind/TeaGo/utils/time"
"testing"
"time"
@@ -8,23 +9,31 @@ import (
func TestUnixTime(t *testing.T) {
for i := 0; i < 5; i++ {
t.Log(UnixTime(), "real:", time.Now().Unix())
t.Log(utils.UnixTime(), "real:", time.Now().Unix())
time.Sleep(1 * time.Second)
}
}
func TestGMTUnixTime(t *testing.T) {
t.Log(GMTUnixTime(time.Now().Unix()))
t.Log(utils.GMTUnixTime(time.Now().Unix()))
}
func TestGMTTime(t *testing.T) {
t.Log(GMTTime(time.Now()))
t.Log(utils.GMTTime(time.Now()))
}
func TestFloorUnixTime(t *testing.T) {
var timestamp = time.Now().Unix()
t.Log("floor 60:", timestamp, FloorUnixTime(60), timeutil.FormatTime("Y-m-d H:i:s", FloorUnixTime(60)))
t.Log("ceil 60:", timestamp, CeilUnixTime(60), timeutil.FormatTime("Y-m-d H:i:s", CeilUnixTime(60)))
t.Log("floor 300:", timestamp, FloorUnixTime(300), timeutil.FormatTime("Y-m-d H:i:s", FloorUnixTime(300)))
t.Log("next minute:", NextMinuteUnixTime())
t.Log("floor 60:", timestamp, utils.FloorUnixTime(60), timeutil.FormatTime("Y-m-d H:i:s", utils.FloorUnixTime(60)))
t.Log("ceil 60:", timestamp, utils.CeilUnixTime(60), timeutil.FormatTime("Y-m-d H:i:s", utils.CeilUnixTime(60)))
t.Log("floor 300:", timestamp, utils.FloorUnixTime(300), timeutil.FormatTime("Y-m-d H:i:s", utils.FloorUnixTime(300)))
t.Log("next minute:", utils.NextMinuteUnixTime())
}
func TestYmd(t *testing.T) {
t.Log(utils.Ymd())
}
func TestRound5Hi(t *testing.T) {
t.Log(utils.Round5Hi())
}