分布式全局锁
admin
2023-03-19 01:04:26
0

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.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 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());
}


相关内容

热门资讯

【今日要闻】“卡贝大厅开挂神器... 家人们!今天小编来为大家解答卡贝大厅透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
今日重大发现“赏金女王到底是不... 网上科普关于“赏金女王有没有挂”话题很是火热,小编也是针对赏金女王作*弊开挂的方法以及开挂对应的知识...
玩家分享攻略“达人十三水开挂神... 您好:达人十三水这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
原创 以... 2025年12月23日晚间正当我们准备休息时,一位朋友发来了一条信息,“你快看看这个,无法无天了都!...
【第一资讯】“新海贝之城拼三张... 您好:新海贝之城拼三张这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在...
最新引进“青鸾牛牛可以开挂吗?... 家人们!今天小编来为大家解答青鸾牛牛透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...
玩家攻略科普“欢又聊红包究竟有... 有 亲,根据资深记者爆料欢又聊红包是可以开挂的,确实有挂(咨询软件无需打...
【第一消息】“赏金女王有没有挂... 您好:赏金女王这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
【今日要闻】“同乡游麻将是不是... 有 亲,根据资深记者爆料同乡游麻将是可以开挂的,确实有挂(咨询软件无需打...
【今日要闻】“新版悟空怎么开挂... 家人们!今天小编来为大家解答新版悟空透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很...