redis解決分布式定時任務問題

2021-10-15 00:06:45 字數 1014 閱讀 7836

場景分析:

多伺服器針對於定時任務帶來的問題,保證任務只在乙個伺服器上在執行。

解決方案1:

redis

@bean

public defaultredisscript

redisscript()

@scheduled

(cron =

"*/40 * * * * ?"

)public

void

testscheduled()

else

}catch

(interruptedexception e)

}

--獲取key

local key = keys[1]

--獲取value

local val = keys[2]

--超時時間

local expire = ar**[1]

--如果通過key拿不到值,則需要設定值

if redis.call(

"get", key)

==false

then

--上面如果拿到值成功,則看設定val能否成功,只有引數val==redis存的value,才能設定成功

if redis.call(

"set", key, val)

then

--設定成功,檢視超時時間是否有效

if tonumber(expire)

> 0 then

--如果有效,則重置超時時間

redis.call(

"expire", key, expire)

endreturn

true

endreturn

false

else

return

false

end

當然還有其他分布式cron框架解決方案。

分布式定時任務

在做springboot專案的時候,需要定時做對賬任務。但因為專案是集群部署,就存在多個pod例項的定時任務同時執行,存在重複性。怎麼保證集群中不重複地完成定時任務?下面給出本人總結的方案。對賬任務表 merchant idname is done 是否對賬,0沒有對賬 1商家102 商家20 3商...

Redis解決分布式定時任務重複執行問題

問題描述 有乙個定時任務是每週一給客戶傳送郵件的功能,後台部署了2臺伺服器,所以客戶 收到了2封重複郵件。解決思路 分布式鎖一般有三種實現方式 1.資料庫樂觀鎖 2.基於redis的分布式鎖 3.基於zookeeper的分布式鎖。這裡使用一台redis伺服器來解決上面的問題。部分比較簡單 加鎖 主要...

分布式定時任務元件對比

描述xxl job elastic job lite saturn 主要作者 大眾點評徐雪裡 當當網張亮 唯品會開源,基於elastic job 特殊環境 mysql5.7 zookeeper 同elastic job 特殊功能 策略豐富,支援分片 子任務 支援分片,分片策略比xxl job豐富,支...