Java基礎(chǔ)學(xué)習(xí):java定時(shí)器

Java基礎(chǔ)學(xué)習(xí):java定時(shí)器

天津卓眾教育      2022-05-06 14:14:01     78

Java基礎(chǔ)學(xué)習(xí):java定時(shí)器,一、定時(shí)器:  顧名思義,定時(shí)器是定時(shí)執(zhí)行的任務(wù)。定時(shí)器的應(yīng)用場景很廣,比方說,定時(shí)更新排行榜的用戶信息、定時(shí)刷新首頁列

課程價(jià)格 請咨詢

上課時(shí)段: 授課校區(qū):

詳細(xì)介紹

     一、定時(shí)器:

  顧名思義,定時(shí)器是定時(shí)執(zhí)行的任務(wù)。定時(shí)器的應(yīng)用場景很廣,比方說,定時(shí)更新排行榜的用戶信息、定時(shí)刷新首頁列表數(shù)據(jù)到緩存等等

  二、Java中實(shí)現(xiàn)定時(shí)任務(wù)的幾種方式

  1、原生態(tài)Timer,優(yōu)點(diǎn)是方便快速,缺點(diǎn)是每一個(gè)任務(wù)都需要占用一個(gè)線程資源,而且任務(wù)拋異常出去后,定時(shí)任務(wù)下次就不會在執(zhí)行了

  2、ScheduledExecutorService,這是Java5以后提供的一個(gè)類,可以很方便的實(shí)現(xiàn)定時(shí)調(diào)度。

  ScheduledExecutorServiceservice=Executors.newScheduledThreadPool(5);//創(chuàng)建調(diào)度服務(wù),線程池?cái)?shù)量為5

  service.scheduleAtFixedRate(Runnablecommand,longinitialDelay,longperiod,TimeUnitunit);//開啟調(diào)度,command是所要執(zhí)行的任務(wù),initialDelay是初始化延時(shí)時(shí)間,period是調(diào)度周期,unit是時(shí)間單位

  3、Spring提供的定時(shí)器,例如,以下例子是每一分鐘執(zhí)行一次的任務(wù)

  @Scheduled(cron="0*/1***?")

  publicvoidupdateXxx(){...}

  這種方式很方便,而且也是基于線程池的方式,數(shù)量可以通過xml配置。如果項(xiàng)目中有很多定時(shí)任務(wù),那么就需要相對應(yīng)的調(diào)大線程池?cái)?shù)量,不然就得排隊(duì)了。

  三、分布式定時(shí)器所遇到的問題

  分布式定時(shí)器:簡單理解就是多個(gè)定時(shí)器同時(shí)部署,定時(shí)器中的各個(gè)任務(wù)相互協(xié)作

  可能遇到的問題(包括但不限于此):

  1、如何保證多個(gè)定時(shí)器中同一個(gè)任務(wù)只有一個(gè)在執(zhí)行

  2、如何避免死鎖

  3、另一個(gè)詭異的問題是,明明已經(jīng)加鎖了,但還是被重復(fù)執(zhí)行了

  四、解決方案

  多個(gè)定時(shí)器中的同一個(gè)任務(wù)只有一個(gè)在執(zhí)行。這個(gè)時(shí)候光靠Java本身提供的鎖機(jī)制是沒辦法實(shí)現(xiàn)的,需要借助第三方的力量,這里使用的是Redis,因?yàn)樗咝В阅芎?、單?jié)點(diǎn)支持qps已經(jīng)超過了1萬,所以性能是非常高的。其中用到的是Redis的set命令。

  原型是:SETkeyvalue[EXseconds][PXmilliseconds][NX|XX]

  EXsecond:設(shè)置鍵的過期時(shí)間為second秒。

  PXmillisecond:設(shè)置鍵的過期時(shí)間為millisecond毫秒。

  NX:只在鍵不存在時(shí),才對鍵進(jìn)行設(shè)置操作。

  XX:只在鍵已經(jīng)存在時(shí),才對鍵進(jìn)行設(shè)置操作。

  例子:

  setmylock192.168.1.100EX5NX

  上邊的例子中設(shè)置key為mylock,value為192.168.1.100,EX5表示過期時(shí)間為5秒鐘,NX表示當(dāng)key不存在的時(shí)候再設(shè)置。這里為什么要把value設(shè)置為IP呢,原因是可以追蹤是誰占有著這把鎖。

  設(shè)置成功時(shí)返回OK,失敗則返回nil,利用這個(gè)特性就可以實(shí)現(xiàn)分布式鎖了。其中設(shè)置5秒的過期時(shí)間可以避免死鎖的發(fā)生

  以上就是天津卓眾教育java培訓(xùn)機(jī)構(gòu)的小編針對“Java基礎(chǔ)學(xué)習(xí):java定時(shí)器”的內(nèi)容進(jìn)行的回答,希望對大家有所幫助,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。

Java基礎(chǔ)學(xué)習(xí)

培訓(xùn)啦提醒您:交易時(shí)請核實(shí)對方資質(zhì),對于過大宣傳或承諾需謹(jǐn)慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險(xiǎn),謹(jǐn)防上當(dāng)。