真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

分布式全局鎖-創(chuàng)新互聯(lián)

Distlock

參考文檔:http://redis.io/topics/distlock

成都創(chuàng)新互聯(lián)公司客戶idc服務中心,提供四川綿陽服務器托管、成都服務器、成都主機托管、成都雙線服務器等業(yè)務的一站式服務。通過各地的服務中心,我們向成都用戶提供優(yōu)質(zhì)廉價的產(chǎn)品以及開放、透明、穩(wěn)定、高性價比的服務,資深網(wǎng)絡工程師在機房提供7*24小時標準級技術保障。

分布式全局鎖用在:分布式定時任務(執(zhí)行前取鎖),問醫(yī)生(醫(yī)生回答問題前取鎖)

設計原理:使用redis SET resource_name my_random_value NX PX 30000,當鍵不存在時才set值,鍵為鎖的標識,值為該鎖的刪除驗證碼,用于刪除鎖時使用

具體流程:1.操作前拿鎖,并設置刪除碼。2.執(zhí)行業(yè)務操作。3.通過鎖鍵拿到鎖值,如果鎖值與之前設置的刪除碼一致,則刪除該鎖,如果不一致,則需要考慮鎖過期,別人已經(jīng)拿到鎖做了相關業(yè)務,自己的業(yè)務是否需要回滾。

實際使用:

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需要以標準前綴(手動指定 微服務名: 或 緩存自動指定 類名完整路徑) 不是該結(jié)構的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());
}

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


分享標題:分布式全局鎖-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://weahome.cn/article/gisgd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部