mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:50:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			161 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			161 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package models
 | 
						|
 | 
						|
import (
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/errors"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/goman"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/remotelogs"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/utils"
 | 
						|
	_ "github.com/go-sql-driver/mysql"
 | 
						|
	"github.com/iwind/TeaGo/Tea"
 | 
						|
	"github.com/iwind/TeaGo/dbs"
 | 
						|
	"github.com/iwind/TeaGo/maps"
 | 
						|
	"github.com/iwind/TeaGo/rands"
 | 
						|
	timeutil "github.com/iwind/TeaGo/utils/time"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
type NodeTrafficDailyStatDAO dbs.DAO
 | 
						|
 | 
						|
func init() {
 | 
						|
	dbs.OnReadyDone(func() {
 | 
						|
		// 清理数据任务
 | 
						|
		var ticker = time.NewTicker(time.Duration(rands.Int(24, 48)) * time.Hour)
 | 
						|
		goman.New(func() {
 | 
						|
			for range ticker.C {
 | 
						|
				err := SharedNodeTrafficDailyStatDAO.CleanDefaultDays(nil, 32) // 只保留N天
 | 
						|
				if err != nil {
 | 
						|
					remotelogs.Error("NodeTrafficDailyStatDAO", "clean expired data failed: "+err.Error())
 | 
						|
				}
 | 
						|
			}
 | 
						|
		})
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
func NewNodeTrafficDailyStatDAO() *NodeTrafficDailyStatDAO {
 | 
						|
	return dbs.NewDAO(&NodeTrafficDailyStatDAO{
 | 
						|
		DAOObject: dbs.DAOObject{
 | 
						|
			DB:     Tea.Env,
 | 
						|
			Table:  "edgeNodeTrafficDailyStats",
 | 
						|
			Model:  new(NodeTrafficDailyStat),
 | 
						|
			PkName: "id",
 | 
						|
		},
 | 
						|
	}).(*NodeTrafficDailyStatDAO)
 | 
						|
}
 | 
						|
 | 
						|
var SharedNodeTrafficDailyStatDAO *NodeTrafficDailyStatDAO
 | 
						|
 | 
						|
func init() {
 | 
						|
	dbs.OnReady(func() {
 | 
						|
		SharedNodeTrafficDailyStatDAO = NewNodeTrafficDailyStatDAO()
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
// IncreaseDailyStat 增加统计数据
 | 
						|
func (this *NodeTrafficDailyStatDAO) IncreaseDailyStat(tx *dbs.Tx, clusterId int64, role string, nodeId int64, day string, bytes int64, cachedBytes int64, countRequests int64, countCachedRequests int64, countAttackRequests int64, attackBytes int64) error {
 | 
						|
	if len(day) != 8 {
 | 
						|
		return errors.New("invalid day '" + day + "'")
 | 
						|
	}
 | 
						|
	err := this.Query(tx).
 | 
						|
		Param("bytes", bytes).
 | 
						|
		Param("cachedBytes", cachedBytes).
 | 
						|
		Param("countRequests", countRequests).
 | 
						|
		Param("countCachedRequests", countCachedRequests).
 | 
						|
		Param("countAttackRequests", countAttackRequests).
 | 
						|
		Param("attackBytes", attackBytes).
 | 
						|
		InsertOrUpdateQuickly(maps.Map{
 | 
						|
			"clusterId":           clusterId,
 | 
						|
			"role":                role,
 | 
						|
			"nodeId":              nodeId,
 | 
						|
			"day":                 day,
 | 
						|
			"bytes":               bytes,
 | 
						|
			"cachedBytes":         cachedBytes,
 | 
						|
			"countRequests":       countRequests,
 | 
						|
			"countCachedRequests": countCachedRequests,
 | 
						|
			"countAttackRequests": countAttackRequests,
 | 
						|
			"attackBytes":         attackBytes,
 | 
						|
		}, maps.Map{
 | 
						|
			"bytes":               dbs.SQL("bytes+:bytes"),
 | 
						|
			"cachedBytes":         dbs.SQL("cachedBytes+:cachedBytes"),
 | 
						|
			"countRequests":       dbs.SQL("countRequests+:countRequests"),
 | 
						|
			"countCachedRequests": dbs.SQL("countCachedRequests+:countCachedRequests"),
 | 
						|
			"countAttackRequests": dbs.SQL("countAttackRequests+:countAttackRequests"),
 | 
						|
			"attackBytes":         dbs.SQL("attackBytes+:attackBytes"),
 | 
						|
		})
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	// 触发钩子
 | 
						|
	return this.increaseDailyStatHook(tx, role, nodeId)
 | 
						|
}
 | 
						|
 | 
						|
// FindDailyStats 获取日期之间统计
 | 
						|
func (this *NodeTrafficDailyStatDAO) FindDailyStats(tx *dbs.Tx, role string, nodeId int64, dayFrom string, dayTo string) (result []*NodeTrafficDailyStat, err error) {
 | 
						|
	ones, err := this.Query(tx).
 | 
						|
		Attr("nodeId", nodeId).
 | 
						|
		Attr("role", role).
 | 
						|
		Between("day", dayFrom, dayTo).
 | 
						|
		FindAll()
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	dayMap := map[string]*NodeTrafficDailyStat{} // day => Stat
 | 
						|
	for _, one := range ones {
 | 
						|
		stat := one.(*NodeTrafficDailyStat)
 | 
						|
		dayMap[stat.Day] = stat
 | 
						|
	}
 | 
						|
	days, err := utils.RangeDays(dayFrom, dayTo)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	for _, day := range days {
 | 
						|
		stat, ok := dayMap[day]
 | 
						|
		if ok {
 | 
						|
			result = append(result, stat)
 | 
						|
		} else {
 | 
						|
			result = append(result, &NodeTrafficDailyStat{Day: day})
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return result, nil
 | 
						|
}
 | 
						|
 | 
						|
// SumDailyStat 计算日期之间的总和
 | 
						|
func (this *NodeTrafficDailyStatDAO) SumDailyStat(tx *dbs.Tx, role string, nodeId int64, dayFrom string, dayTo string) (*NodeTrafficDailyStat, error) {
 | 
						|
	one, err := this.Query(tx).
 | 
						|
		Result("SUM(bytes) AS bytes", "SUM(cachedBytes) AS cachedBytes", "SUM(countRequests) AS countRequests", "SUM(countCachedRequests) AS countCachedRequests", "SUM(countAttackRequests) AS countAttackRequests", "SUM(attackBytes) AS attackBytes").
 | 
						|
		Attr("nodeId", nodeId).
 | 
						|
		Attr("role", role).
 | 
						|
		Between("day", dayFrom, dayTo).
 | 
						|
		Find()
 | 
						|
	if err != nil || one == nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	return one.(*NodeTrafficDailyStat), nil
 | 
						|
}
 | 
						|
 | 
						|
// CleanDays 清理历史数据
 | 
						|
func (this *NodeTrafficDailyStatDAO) CleanDays(tx *dbs.Tx, days int) error {
 | 
						|
	var day = timeutil.Format("Ymd", time.Now().AddDate(0, 0, -days))
 | 
						|
	_, err := this.Query(tx).
 | 
						|
		Lt("day", day).
 | 
						|
		Delete()
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
func (this *NodeTrafficDailyStatDAO) CleanDefaultDays(tx *dbs.Tx, defaultDays int) error {
 | 
						|
	databaseConfig, err := SharedSysSettingDAO.ReadDatabaseConfig(tx)
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	if databaseConfig != nil && databaseConfig.NodeTrafficDailyStat.Clean.Days > 0 {
 | 
						|
		defaultDays = databaseConfig.NodeTrafficDailyStat.Clean.Days
 | 
						|
	}
 | 
						|
	if defaultDays <= 0 {
 | 
						|
		defaultDays = 32
 | 
						|
	}
 | 
						|
 | 
						|
	return this.CleanDays(tx, defaultDays)
 | 
						|
}
 |