Esempio n. 1
0
        public string SetDisabled()
        {
            var _result = new { state = 0, result = 0, msg = "" };
            var result  = SE_GiftManageConfigBLL.SetDisabled();

            if (result >= 0)
            {
                using (var client = new Tuhu.Service.Product.CacheClient())
                {
                    var cacheresult = client.RefreshGiftCache();
                    if (cacheresult.Result)
                    {
                        _result = new { state = 1, result = result, msg = "" }
                    }
                    ;
                    else
                    {
                        _result = new { state = 0, result = 0, msg = cacheresult.ErrorMessage }
                    };
                }
            }
            else
            {
                _result = new { state = 0, result = 0, msg = "操作失败请重试" };
            }
            return(Newtonsoft.Json.JsonConvert.SerializeObject(_result));
        }
Esempio n. 2
0
        public string RefreshCache()
        {
            var _result = new { state = 0, msg = "" };

            try
            {
                using (var client = new Tuhu.Service.Product.CacheClient())
                {
                    var result = client.RefreshGiftCache();
                    if (result.Result)
                    {
                        _result = new { state = 1, msg = "" }
                    }
                    ;
                    else
                    {
                        _result = new { state = 0, msg = result.ErrorMessage }
                    };
                }
            }
            catch (Exception ex)
            {
                _result = new { state = 0, msg = ex.ToString() };
            }
            return(Newtonsoft.Json.JsonConvert.SerializeObject(_result));
        }
Esempio n. 3
0
 public void Execute(IJobExecutionContext context)
 {
     try
     {
         Logger.Info("开始刷新城市缓存");
         var cityids = DAL.ProductCacheDal.SelectCityIds();
         if (cityids != null && cityids.Any())
         {
             Logger.Info($"开始刷新城市缓存 共{cityids.Count()}个.");
             foreach (var cityid in cityids)
             {
                 using (var client = new Tuhu.Service.Product.CacheClient())
                 {
                     Logger.Info($"开始刷新{cityid}");
                     var result = client.RefreshProductsRegionStockCache(cityid, new List <string>());
                     Logger.Info($"结束刷新{cityid}.Success:{result.Success}");
                     result.ThrowIfException(true);
                 }
             }
         }
     }
     catch (System.Exception ex)
     {
         Logger.Warn(ex);
     }
     Logger.Info("结束刷新城市缓存");
 }
        public void Execute(IJobExecutionContext context)
        {
            Logger.Info($"开始刷新");
            int count  = 0;
            var result = ProductCacheDal.SelectCommonProductEsPids(500);

            if (result != null)
            {
                Parallel.ForEach(result, new ParallelOptions()
                {
                    MaxDegreeOfParallelism = 4,
                    TaskScheduler          = TaskScheduler.Default
                }, parseitem =>
                {
                    count++;
                    Logger.Info($"开始刷新{count}批次");
                    if (parseitem != null && parseitem.Any())
                    {
                        var setitems = (from item in parseitem.AsParallel()
                                        group item by item.Value
                                        into g
                                        select new
                        {
                            items = g.Select(x => x.Key)?.ToList(),
                            type = g.Key
                        })?.ToList();
                        foreach (var setitem in setitems)
                        {
                            try
                            {
                                using (var client = new Tuhu.Service.Product.CacheClient())
                                {
                                    var setresult = client.SetEsCacheByPids(setitem.items, setitem.type);
                                    setresult.ThrowIfException(true);
                                }
                            }
                            catch (System.Exception ex)
                            {
                                Logger.Warn(ex);
                            }
                        }
                    }
                    Logger.Info($"结束刷新{count}批次");
                });
            }

            Logger.Info($"结束刷新");
        }
Esempio n. 5
0
 public void Execute(IJobExecutionContext context)
 {
     try
     {
         Logger.Info("开始刷新人工推荐缓存");
         var batch         = 200;
         var i             = 0;
         var vehicleInfors = DAL.ProductCacheDal.SelectManualTireSortSize();
         if (vehicleInfors != null && vehicleInfors.Any())
         {
             Logger.Info($"开始刷新人工推荐缓存-->{vehicleInfors.Count()}-->总页数:{vehicleInfors.Count % batch}");
             foreach (var oneBatch in vehicleInfors.Split(batch))
             {
                 Thread.Sleep(500);
                 Logger.Info($"开始刷新{++i}");
                 var requestList = new List <SearchProductRequest>();
                 oneBatch.ForEach(p =>
                 {
                     var tireSize = TireSizeModel.Parse(p.TireSize);
                     if (tireSize != null)
                     {
                         requestList.Add(new SearchProductRequest()
                         {
                             VehicleId  = p.VehicleId,
                             Parameters = new Dictionary <string, IEnumerable <string> >
                             {
                                 ["CP_Tire_Width"]       = new[] { tireSize.Width },
                                 ["CP_Tire_AspectRatio"] = new[] { tireSize.AspectRatio },
                                 ["CP_Tire_Rim"]         = new[] { tireSize.Rim },
                             }
                         });
                     }
                 });
                 using (var client = new Tuhu.Service.Product.CacheClient())
                 {
                     var result = client.RefreshManualTireSort(requestList);
                     result.ThrowIfException(true);
                 }
             }
         }
     }
     catch (System.Exception ex)
     {
         Logger.Warn(ex);
     }
     Logger.Info("结束刷新BI推荐缓存");
 }
Esempio n. 6
0
        public void Execute(IJobExecutionContext context)
        {
            int pagesize = 10;

            try
            {
                var results = SelectProductExtraPropertiesPids(pagesize);
                if (results != null && results.Any())
                {
                    logger.Info($"开始刷新,一共{totalcount / pagesize}批次");
                    int count = 0;
                    foreach (var pids in results)
                    {
                        try
                        {
                            count++;
                            logger.Info($"开始刷新{count}批次,一共{totalcount / pagesize}批次");
                            if (pids != null && pids.Any() && pids.Any(x => !string.IsNullOrEmpty(x)))
                            {
                                using (var client = new Tuhu.Service.Product.CacheClient())
                                {
                                    var cacheresult = client.RefreshProductExtraPropertiesCache(pids.Where(x => !string.IsNullOrEmpty(x)));
                                    logger.Info($"结束刷新{count}批次,一共{totalcount / pagesize}批次.success:{cacheresult.Result}");
                                }
                            }
                        }
                        catch (System.Exception ex)
                        {
                            logger.Warn($"刷新产品扩展信息缓存,ex:{ex}");
                        }
                    }
                }
            }
            catch (System.Exception ex)
            {
                logger.Warn($"刷新扩展信息缓存:{ex}");
            }
        }