博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
分布式全局锁
阅读量:6976 次
发布时间:2019-06-27

本文共 1307 字,大约阅读时间需要 4 分钟。

Distlock

参考文档:http://redis.io/topics/distlock

分布式全局锁用在:分布式定时任务(执行前取锁),问医生(医生回答问题前取锁)

设计原理:使用redis SET resource_name my_random_value NX PX 30000,当键不存在时才set值,键为锁的标识,值为该锁的删除验证码,用于删除锁时使用

具体流程:1.操作前拿锁,并设置删除码。2.执行业务操作。3.通过锁键拿到锁值,如果锁值与之前设置的删除码一致,则删除该锁,如果不一致,则需要考虑锁过期,别人已经拿到锁做了相关业务,自己的业务是否需要回滚。

实际使用:

1.pom加入redis依赖:

    
org.springframework.boot
    
spring-boot-starter-redis

2.application.properties 配置redis服务器

spring.application.name=provider-service#使用哨兵,不手动指定redis服务器spring.redis.host=10.3.5.21spring.redis.port=6379#spring.redis.sentinel.master=master1#spring.redis.sentinel.nodes=10.3.5.36:26379,10.3.5.38:26379#微服务专用database 所有key需要以标准前缀(手动指定 微服务名: 或 缓存自动指定 类名完整路径) 不是该结构的key全部删除spring.redis.database=2spring.redis.timeout=10000

3.使用分布式全局锁

@Value("${spring.application.name}")private String appName;@Inject@Resource(name = "redisTemplate")private ValueOperations
 valueOperations;@Scheduled(cron = "0 58 * * * ?")public void foo(){    if(!RedisDistributedLock.lock(valueOperations, appName+":lock_BarService.foo()", "", 60)){        System.out.println("EnableScheduling return.");        return;    }    System.out.println("EnableScheduling "+System.currentTimeMillis());}
      本文转自yushiwh 51CTO博客,原文链接:http://blog.51cto.com/yushiwh/1942251,如需转载请自行联系原作者
你可能感兴趣的文章
浏览器是怎样工作的:渲染引擎,HTML解析
查看>>
centos下LAMP之源码编译安装httpd
查看>>
EBS form日历可选范围设置(calendar.setup )介绍
查看>>
myeclipse莫名其妙的问题
查看>>
iOS-UIWebView添加头部和尾部
查看>>
你最需要了解的H3C交换机端口安全模式
查看>>
常用Linux路由命令(route、ip、ifconfig等等)
查看>>
高可用集群之分布式文件系统
查看>>
LINUX内核升级
查看>>
lanmp v2.4一键安装包(包括lamp,lnmp,lnamp安装)
查看>>
将视觉深度学习模型应用于非视觉领域
查看>>
一步步构建大型网站架构
查看>>
阿里云安全肖力:安全基础建设是企业数字化转型的基石
查看>>
iphone X系列设配屏幕适配
查看>>
查看进程 端口
查看>>
连接centos7桌面方法
查看>>
我的友情链接
查看>>
eclipse设置
查看>>
第二课 , 启动 ./start-all.sh
查看>>
windows 2012 nps配置
查看>>