参考文档:http://redis.io/topics/distlock
成都创新互联公司一直秉承“诚信做人,踏实做事”的原则,不欺瞒客户,是我们最起码的底线! 以服务为基础,以质量求生存,以技术求发展,成交一个客户多一个朋友!为您提供成都做网站、成都网站建设、成都网页设计、微信小程序定制开发、成都网站开发、成都网站制作、成都软件开发、成都app软件开发是成都本地专业的网站建设和网站设计公司,等你一起来见证!
分布式全局锁用在:分布式定时任务(执行前取锁),问医生(医生回答问题前取锁)
设计原理:使用redis SET resource_name my_random_value NX PX 30000,当键不存在时才set值,键为锁的标识,值为该锁的删除验证码,用于删除锁时使用
具体流程:1.操作前拿锁,并设置删除码。2.执行业务操作。3.通过锁键拿到锁值,如果锁值与之前设置的删除码一致,则删除该锁,如果不一致,则需要考虑锁过期,别人已经拿到锁做了相关业务,自己的业务是否需要回滚。
实际使用:
1.pom加入redis依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-redis</artifactId> </dependency>
2.application.properties 配置redis服务器
spring.application.name=provider-service #使用哨兵,不手动指定redis服务器 spring.redis.host=10.3.5.21 spring.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=2 spring.redis.timeout=10000
3.使用分布式全局锁
@Value("${spring.application.name}") private String appName; @Inject @Resource(name = "redisTemplate") private ValueOperations<String, String> 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()); }
本文题目:分布式全局锁
当前地址:https://www.cdcxhl.com/article48/pcjoep.html
成都网站建设公司_创新互联,为您提供建站公司、动态网站、网站营销、外贸建站、网站改版、ChatGPT
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联