关于集群定时任务的分布式锁解决方案

关于集群定时任务的分布式锁解决方案

业务场景:同样的后端服务要部署多台服务器,要求同一时间只有一台服务器在跑定时任务,并且当其中任何一台或者多台服务宕机,剩余服务器仍能执行任务。
方案:每台服务器的代码和配置文件一致。设计新表,除了主键id之外有一个lock字段(0表示解锁,1表示锁定)。设计之初设为0。
现在假设有三台集群服务器同时在跑定时任务,假设三台服务器同时进入定时任务,执行更新语句:update table_name set lock=1 where lock=0;此时根据数据库的事务机制,只可能有一台服务器执行成功,另外两台服务器执行时lock已经变成1了,where条件不成立,那么数据库就会返回false,根据这个返回结果定时任务就不继续往下执行。保证了同时只有一台服务器往下跑定时任务。返回成功的那台服务器执行完此次任务后,执行sql语句:update table_name set lock=0 where lock=1;把数据库的lock值恢复,以备下次定时任务的执行

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值