Esempio n. 1
0
        public async Task <ResponseMessage> LotteryRun()
        {
            Logger.Trace($"彩票开始开奖");
            var response = new ResponseMessage();
            var prefixs  = new string[] { "lottery" };
            var key      = "lottery";

            try
            {
                // 防止同时重复提交
                await _cache.LockSubmit(prefixs, key, "lottery", HttpContext.RequestAborted);

                response = await _giftManager.LotteryRunAsync(HttpContext.RequestAborted);

                if (response.Code != ResponseCodeDefines.SuccessCode)
                {
                    Logger.Warn($"彩票开始开奖,失败:{JsonHelper.ToJson(response)}");
                }
            }
            catch (Exception e)
            {
                response.Code    = ResponseCodeDefines.ServiceError;
                response.Message = e.Message;
                Logger.Error($"彩票开始开奖,报错:{e.Message}\r\n{e.StackTrace}");
            }
            finally
            {
                // 成功失败都要移除
                await _cache.UnlockSubmit(prefixs, key);
            }
            return(response);
        }