前言
上周“被”上线了一个紧急项目,周五下班接到需求,周一开始思考解决方案,周三开发完成,周四走流程上线,也算是面向领导编程了。之前的项目里面由于是自运维,然后大多数又都赶时间,所以在处理定时任务上面基本都是自己在服务器上添加crontab,而不是让多个实例自己去处理定时任务的并发锁,并且Laravel 5.5开始自带并发锁,我们也快升级了。但是这次项目是Python项目,无奈只能自己实现一下,以下这个方案实现起来非常简单且易于理解。
import redis
r = redis.Redis(...)
last_heart = 0 # 记录上一次得到的锁心跳
free_lock_try = 6 # 锁无心跳的最大次数
while not r.setnx('mylock', 1):
now_heart = r.get('mylock')
print(f"没获取到锁,now_heart={now_heart},last_heart={last_heart},free_lock_try={free_lock_try}")
if now_heart == last_heart:
free_lock_try = free_lock_try - 1
if free_lock_try == 0: # 锁已经1分钟没有心跳了
old_heart = r.getset('mylock', 1) # 将lock重置为1,并返回set之前的心跳值
if old_heart < now_heart:
time.sleep(10)
continue
else:
break # 成功获取到锁,退出循环
else:
free_lock_try = 6 # 锁有心跳,重置free_lock_try值
last_heart = now_heart
time.sleep(10)
def producer_exit():
"""程序正常退出时候自动清理锁"""
r.delete('mylock')
import atexit
atexit.register(producer_exit)
# 业务代码
while True:
r.incr('mylock') # 让锁心跳加一
...
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容- Java Arrays 类中 copyOfRange 的使用场景有哪些?(Java Arrays类中copyOfRange的使用场景)
- 如何设置 Java Kubernetes 安全策略?(java kubernetes安全策略如何设置)
- 有哪些常用的 java 文本编辑器?(常用的java文本编辑器有哪些)
- Java中 AOP 的应用场景具体有哪些?(java中aop的应用场景有哪些)
- 如何在 Java 中实现踢人下线功能?(Java怎么实现踢人下线功能)
- Java 交换器(exchanger)的替代方案都有哪些呢?(java exchanger的替代方案有哪些)
- Java 中如何使用 JsonNode 来解析 JSON 数据?(Java JsonNode如何解析JSON数据)
- 如何进行Ruby代码安全检测
- 在 Java 中如何设置 Swing 的背景图片?(java中swing如何设置背景图片)
- Java 输入输出流出现问题该如何解决?(Java输入输出流出现问题怎么解决)
猜你喜欢
AI推送时光机如何使用Redis锁处理并发问题详解
数据库2024-04-02
SpringBoot如何使用 Redis 分布式锁解决并发问题
数据库2023-06-25
Python使用future处理并发问题方案详解
数据库2023-02-08
Redis如何处理并发访问
数据库2024-04-09
关于SpringBoot 使用 Redis 分布式锁解决并发问题
数据库2024-04-02
Redis如何解决高并发问题
数据库2024-04-02
如何解决redis的并发问题
数据库2024-04-02
java并发问题如何处理
数据库2017-08-03
C#开发中如何处理并发编程和死锁问题
数据库2023-10-22
ASP 中如何处理并发问题?
数据库2023-11-12
使用redis分布式锁解决并发线程资源共享问题
数据库2024-04-02
redis单线程并发问题如何解决
数据库2023-09-11
springboot利用redis、Redisson处理并发问题的操作
数据库2024-04-02
C#开发中如何处理并发访问问题
数据库2023-10-22
Golang的高并发场景中如何处理死锁和饥饿问题?
数据库2024-05-10
python3使用python-redis-lock解决并发计算问题
数据库2024-04-02
C#使用读写锁解决多线程并发问题
数据库2024-04-02
ASP编程:如何使用算法处理同步和并发问题?
数据库2023-07-07
详解利用redis + lua解决抢红包高并发的问题
数据库2022-06-04
咦!没有更多了?去看看其它编程学习网 内容吧