From e5df488268e29b272932e6cc1d2b1e7034590ba0 Mon Sep 17 00:00:00 2001 From: zhangqian <zhangqian@123.com> Date: 星期三, 12 六月 2024 11:40:45 +0800 Subject: [PATCH] weedfs包放到项目里 --- task/month_stats.go | 48 +++++++++++++++++++++++++++++------------------- 1 files changed, 29 insertions(+), 19 deletions(-) diff --git a/task/month_stats.go b/task/month_stats.go index b89aa88..7a507f0 100644 --- a/task/month_stats.go +++ b/task/month_stats.go @@ -12,21 +12,25 @@ "wms/service" ) -func MonthStats() { +func MonthStats() (err error) { //鍔犻攣锛屽彧闇�瑕佷竴涓繘绋嬭繍琛屾浠诲姟 var ( lockName = "monthStats" serviceID = "wms" ) - err := models.NewLockSearch().AcquireLock(lockName, serviceID) + err = models.NewLockSearch().AcquireLock(lockName, serviceID) if err != nil { logx.Errorf("MonthStats AcquireLock err:%v", err) return } defer func() { - err := models.NewLockSearch().ReleaseLock(lockName, serviceID) + if err != nil { + service.SendAlarm("鏈堝害缁熻鎵ц澶辫触", "鎶ラ敊: "+err.Error()) + } + err = models.NewLockSearch().ReleaseLock(lockName, serviceID) if err != nil { logx.Errorf("MonthStats ReleaseLock err:%v", err) + service.SendAlarm("鏈堝害缁熻鎵ц鎴愬姛瑙i攣澶辫触", err.Error()) } }() @@ -68,6 +72,12 @@ return } var record models.MonthStats + + err = models.NewMonthStatsSearch().SetDate(date).Delete() + if err != nil { + return + } + for _, groupSum := range groupSumList { productId := groupSum.Class if productMap[productId] == nil { @@ -126,11 +136,6 @@ } } - err = models.NewMonthStatsSearch().SetDate(date).Delete() - if err != nil { - return - } - record.BeginMoreUnits = moreUnits err = models.WithTransaction(func(db *gorm.DB) error { err = models.NewMonthStatsSearch().SetOrm(db).Create(&record) @@ -139,18 +144,20 @@ service.SendAlarm("鏈堝害缁熻鍒涘缓鏈湀澶辫触", fmt.Sprintf("NewMonthStatsSearch Create err:%v, record: %+v", err, record)) } - if oldRecordsMap[productId] != nil && (!inputMap[productId].IsZero() || !outputMap[productId].IsZero()) { - record.InputAmount = inputMap[productId] - record.InputMoreUnits = inputMoreUnits - record.OutputAmount = outputMap[productId] - record.OutputMoreUnits = outputMoreUnits + if oldRecordsMap[productId] != nil { m := map[string]interface{}{ - "input_amount": inputMap[productId], - "input_more_units": inputMoreUnits, - "output_amount": outputMap[productId], - "output_more_units": outputMoreUnits, - "end_more_units": moreUnits, - "end_amount": amount, + "end_more_units": moreUnits, + "end_amount": amount, + } + if !inputMap[productId].IsZero() || !outputMap[productId].IsZero() { + record.InputAmount = inputMap[productId] + record.InputMoreUnits = inputMoreUnits + record.OutputAmount = outputMap[productId] + record.OutputMoreUnits = outputMoreUnits + m["input_amount"] = inputMap[productId] + m["input_more_units"] = inputMoreUnits + m["output_amount"] = outputMap[productId] + m["output_more_units"] = outputMoreUnits } err = models.NewMonthStatsSearch().SetOrm(db).SetID(oldRecordsMap[productId].Id).UpdateByMap(m) if err != nil { @@ -161,6 +168,9 @@ return nil }) } + if err == nil { + service.SendAlarm("鏈堝害缁熻鎵ц鎴愬姛", "") + } return } -- Gitblit v1.8.0