并发处理

This commit is contained in:
Rosy-zhudan
2019-07-31 11:03:36 +08:00
parent b225f814ec
commit c3f6719c6d

View File

@@ -9,19 +9,22 @@ import (
"git.rosy.net.cn/jx-callback/business/partner" "git.rosy.net.cn/jx-callback/business/partner"
"git.rosy.net.cn/jx-callback/business/partner/putils" "git.rosy.net.cn/jx-callback/business/partner/putils"
"git.rosy.net.cn/baseapi" "git.rosy.net.cn/baseapi"
"git.rosy.net.cn/jx-callback/business/jxutils/tasksch"
) )
const ( const (
specialSkuName = "温馨提示" specialSkuName = "温馨提示"
startOpStoreStockNumber = 0 startOpStoreStockNumber = 0
endOpStoreStockNumber = model.MaxStoreSkuStockQty endOpStoreStockNumber = model.MaxStoreSkuStockQty
startOpStoreTimeDefault = int16(5) startOpStoreTimeDefaultMTWM = int16(2200)
endOpStoreTimeDefault = int16(2355) endOpStoreTimeDefaultMTWM = int16(2355)
startOpStoreTimeDefaultEBAI = int16(5)
endOpStoreTimeDefaultEBAI = int16(2355)
) )
var ( var (
startOpStoreTimeList = []string { startOpStoreTimeList = []string {
"00:00:00", "22:00:00",
} }
endOpStoreTimeList = []string { endOpStoreTimeList = []string {
"06:00:00", "06:00:00",
@@ -50,6 +53,16 @@ func GetStockValue(isStart bool) int {
} }
} }
func GetOpStoreTime(vendorID int) (startTime, endTime int16) {
if vendorID == model.VendorIDMTWM {
return startOpStoreTimeDefaultMTWM, endOpStoreTimeDefaultMTWM
} else if vendorID == model.VendorIDEBAI {
return startOpStoreTimeDefaultEBAI, endOpStoreTimeDefaultEBAI
}
return 0, 0
}
func FilterSkuNameList(storeSkuNameList []*partner.SkuNameInfo) (filterStoreSkuNameList []*partner.SkuNameInfo) { func FilterSkuNameList(storeSkuNameList []*partner.SkuNameInfo) (filterStoreSkuNameList []*partner.SkuNameInfo) {
for _, skuNameInfo := range storeSkuNameList { for _, skuNameInfo := range storeSkuNameList {
if skuNameInfo.Name != specialSkuName { if skuNameInfo.Name != specialSkuName {
@@ -62,31 +75,31 @@ func FilterSkuNameList(storeSkuNameList []*partner.SkuNameInfo) (filterStoreSkuN
func StartOrEndOpStore(isStart bool, startTime, endTime int16) { func StartOrEndOpStore(isStart bool, startTime, endTime int16) {
startProcessTime := time.Now().Unix() startProcessTime := time.Now().Unix()
baseapi.SugarLogger.Debugf("StartOrEndOpStore start time: %v", time.Now()) baseapi.SugarLogger.Debugf("StartOrEndOpStore start time: %v", time.Now())
startOpStoreTime := startOpStoreTimeDefault
endOpStoreTime := endOpStoreTimeDefault
if startTime != 0 && endTime != 0 {
startOpStoreTime = startTime
endOpStoreTime = endTime
baseapi.SugarLogger.Debugf("SetStoreOptime:%d do:%d", startTime, endTime)
}
ctx := jxcontext.AdminCtx ctx := jxcontext.AdminCtx
storeInfo, err := cms.GetStores(ctx, "", map[string]interface{}{}, 0, -1, utils.DefaultTimeValue, utils.DefaultTimeValue, 0, 0) storeInfo, err := cms.GetStores(ctx, "", map[string]interface{}{}, 0, -1, utils.DefaultTimeValue, utils.DefaultTimeValue, 0, 0)
if err != nil { if err != nil {
baseapi.SugarLogger.Errorf("storeInfo error:%v", err) baseapi.SugarLogger.Errorf("storeInfo error:%v", err)
} else { } else {
for _, storeListValue := range storeInfo.Stores { taskFunc := func(task *tasksch.ParallelTask, batchItemList []interface{}, params ...interface{}) (retVal interface{}, err error) {
storeListValue := batchItemList[0].(*cms.StoreExt)
storeID := storeListValue.ID storeID := storeListValue.ID
if storeListValue.StoreMaps != nil { if storeListValue.StoreMaps != nil {
for _, vendorListValue := range storeListValue.StoreMaps { for _, vendorListValue := range storeListValue.StoreMaps {
vendorID := int(utils.MustInterface2Int64(vendorListValue["vendorID"])) vendorID := int(utils.MustInterface2Int64(vendorListValue["vendorID"]))
if _, ok := vendorList[vendorID]; ok { if _, ok := vendorList[vendorID]; ok {
startOpStoreTime, endOpStoreTime := GetOpStoreTime(vendorID)
if startTime != 0 && endTime != 0 {
startOpStoreTime = startTime
endOpStoreTime = endTime
baseapi.SugarLogger.Debugf("SetStoreOptime:%d do:%d", startTime, endTime)
}
vendorStoreID := utils.Interface2String(vendorListValue["vendorStoreID"]) vendorStoreID := utils.Interface2String(vendorListValue["vendorStoreID"])
baseapi.SugarLogger.Debugf("storeID:%d vendorID:%d vendorStoreID:%s", storeID, vendorID, vendorStoreID) baseapi.SugarLogger.Debugf("storeID:%d vendorID:%d vendorStoreID:%s", storeID, vendorID, vendorStoreID)
singleStoreHandler := partner.GetPurchasePlatformFromVendorID(vendorID).(partner.ISingleStoreStoreSkuHandler) singleStoreHandler := partner.GetPurchasePlatformFromVendorID(vendorID).(partner.ISingleStoreStoreSkuHandler)
storeSkuNameList, err := singleStoreHandler.GetStoreSkusFullInfo(ctx, nil, storeID, vendorStoreID, nil) storeSkuNameList, err := singleStoreHandler.GetStoreSkusFullInfo(ctx, nil, storeID, vendorStoreID, nil)
if err != nil { if err != nil {
baseapi.SugarLogger.Errorf("storeSkuList error:%v", err) baseapi.SugarLogger.Errorf("storeSkuNameList error:%v storeID:%d vendorID:%d vendorStoreID:%s", err, storeID, vendorID, vendorStoreID)
} else { } else {
filterStoreSkuNameList := FilterSkuNameList(storeSkuNameList) filterStoreSkuNameList := FilterSkuNameList(storeSkuNameList)
storeSkuList := putils.StoreSkuFullList2Bare(filterStoreSkuNameList) storeSkuList := putils.StoreSkuFullList2Bare(filterStoreSkuNameList)
@@ -105,7 +118,7 @@ func StartOrEndOpStore(isStart bool, startTime, endTime int16) {
//baseapi.SugarLogger.Debugf("successList:%v error:%v", successList, err) //baseapi.SugarLogger.Debugf("successList:%v error:%v", successList, err)
} }
return nil, err return nil, err
}, ctx, nil, storeSkuList, singleStoreHandler.GetStoreSkusBatchSize(partner.FuncUpdateStoreSkusStock), true) }, ctx, task, storeSkuList, singleStoreHandler.GetStoreSkusBatchSize(partner.FuncUpdateStoreSkusStock), true)
if isStart { if isStart {
AddOrDelExtraStoreOptime(vendorID, storeID, vendorStoreID, &storeListValue.Store, startOpStoreTime, endOpStoreTime, true) AddOrDelExtraStoreOptime(vendorID, storeID, vendorStoreID, &storeListValue.Store, startOpStoreTime, endOpStoreTime, true)
@@ -115,6 +128,13 @@ func StartOrEndOpStore(isStart bool, startTime, endTime int16) {
} }
} }
} }
return retVal, err
}
task := tasksch.NewParallelTask("StartOrEndOpStore", nil, ctx, taskFunc, storeInfo.Stores)
tasksch.HandleTask(task, nil, true).Run()
_, err = task.GetResult(0)
if err != nil {
baseapi.SugarLogger.Errorf("tasksch error:%v", err)
} }
} }
endProcessTime := time.Now().Unix() endProcessTime := time.Now().Unix()