DelayQueue延時(shí)隊(duì)列

需求場景

(Delay)代碼需要延時(shí)執(zhí)行,(Queue)需要不斷失敗重試

實(shí)例

當(dāng)前時(shí)間延時(shí)5s執(zhí)行Task,并在Task中添加一個(gè)指定時(shí)間執(zhí)行的延時(shí)隊(duì)列
try { 
     //第一個(gè)參數(shù): 延時(shí)任務(wù)中需要使用的參數(shù)對象,
     //第二個(gè)參數(shù): 傳入new Date()作為延時(shí)的基準(zhǔn)時(shí)間 
     DelayGetPrise delay = new DelayGetPrise(asset, new Date());
     GetOpenPriseTask.addtask(delay);
} catch (Exception e) {
     e.printStackTrace();
}
/**
 * @Auther: Young
 * @Date: 2019/4/13 10:28
 * @Description:
 */
@Data
public class DelayGetPrise  implements Delayed {

    public DelayGetPrise(Asset asset, Date endDate)
    {
        this.asset = asset;
        this.endDate = endDate.getTime();
    }

    private long endDate;

    private Asset asset;  //獲取的時(shí)間

    @Override
    //調(diào)用處傳入時(shí)間的基礎(chǔ)上延時(shí) 5s鐘后執(zhí)行task
    public long getDelay(TimeUnit unit) {
        return (endDate + 5000) - System.currentTimeMillis();
    }

    @Override
    public int compareTo(Delayed o) {
        DelayGetPrise jia = (DelayGetPrise) o;
        if (this.endDate - jia.getEndDate() > 0)
            //時(shí)間到達(dá)
            return 1;
        else
            return 0;
    }
}
/**
 * @Auther: Young
 * @Date: 2019/4/13 10:27
 * @Description:該方法繼承AfterSpringLoaded,項(xiàng)目啟動(dòng)后就加載Task,初始化隊(duì)列等
 */
@Component
public class GetOpenPriseTask implements AfterSpringLoaded {

    private static final Logger logger = LoggerFactory.getLogger(GetOpenPriseTask.class);

    @Autowired
    private AssetService assetService;

    @Autowired
    private MarketService marketService;

    private static final BlockingQueue<DelayGetPrise> getOpenPriseQueue = new DelayQueue<DelayGetPrise>();

    public static void addtask(DelayGetPrise dalay) {
        getOpenPriseQueue.add(dalay);
    }

    @Override
    public void load() {
        while (true) {
            try {
                logger.info("task任務(wù) 開始");
                DelayGetPrise prise = getOpenPriseQueue.take();
                try {
                    Asset asset = prise.getAsset();
                    ...
                    //失敗重試
                    if (失敗) {
                        logger.error("Task任務(wù) 數(shù)據(jù)異常,重試");
                        //注意此處傳入的時(shí)間
                        DelayGetPrise newDelay = new DelayGetPrise(asset, new Date());
                        GetOpenPriseTask.addtask(newDelay);
                        //此處不能用break,否則會(huì)跳出while(true),關(guān)閉隊(duì)列
                        continue;
                    } else {
                        logger.info("Task任務(wù) 正常邏輯執(zhí)行");
                        ...
                        logger.info("Task任務(wù)完成");

                        LFExcuter.excute(() -> {
                             try {
                                  //指定時(shí)間延時(shí)Task
                                  int delay = asset.getPeriodValue().multiply(new BigDecimal(6)).intValue();
                                  Calendar calUp = Calendar.getInstance();
                                  int delaysecond = RandomUtil.randomInt(delay + 1);
                                  calUp.add(Calendar.SECOND, delaysecond);
                                  logger.info("指定時(shí)間:delay: " + delaysecond + "秒");
                                  //在計(jì)算好的時(shí)間基礎(chǔ)上延時(shí)
                                  DelayAutoBuy delayAutoUp = new DelayAutoBuy(asset, calUp.getTime(), ExchangeConstant.ORDER_TYPE.UP);
                                  AutoBuyTask.addtask(delayAutoUp);
                                } catch (Exception e) {
                                    logger.error("指定時(shí)間Task任務(wù)", e);
                                }
                            });
                        }
                } catch (Exception e) {
                    logger.error("獲取隊(duì)列錯(cuò)誤,重試Task任務(wù)", e);
                    GetOpenPriseTask.addtask(prise);
                }
            } catch (Exception e) {
                logger.error("指定時(shí)間Task任務(wù) 異常:", e);
            }
            logger.info("Task任務(wù) 結(jié)束");
        }
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容