十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
參考文檔:http://redis.io/topics/distlock
分布式全局鎖用在:分布式定時(shí)任務(wù)(執(zhí)行前取鎖),問(wèn)醫(yī)生(醫(yī)生回答問(wèn)題前取鎖)
設(shè)計(jì)原理:使用redis SET resource_name my_random_value NX PX 30000,當(dāng)鍵不存在時(shí)才set值,鍵為鎖的標(biāo)識(shí),值為該鎖的刪除驗(yàn)證碼,用于刪除鎖時(shí)使用
具體流程:1.操作前拿鎖,并設(shè)置刪除碼。2.執(zhí)行業(yè)務(wù)操作。3.通過(guò)鎖鍵拿到鎖值,如果鎖值與之前設(shè)置的刪除碼一致,則刪除該鎖,如果不一致,則需要考慮鎖過(guò)期,別人已經(jīng)拿到鎖做了相關(guān)業(yè)務(wù),自己的業(yè)務(wù)是否需要回滾。
實(shí)際使用:
1.pom加入redis依賴:
org.springframework.boot spring-boot-starter-redis
2.application.properties 配置redis服務(wù)器
spring.application.name=provider-service #使用哨兵,不手動(dòng)指定redis服務(wù)器 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 #微服務(wù)專用database 所有key需要以標(biāo)準(zhǔn)前綴(手動(dòng)指定 微服務(wù)名: 或 緩存自動(dòng)指定 類名完整路徑) 不是該結(jié)構(gòu)的key全部刪除 spring.redis.database=2 spring.redis.timeout=10000
3.使用分布式全局鎖
@Value("${spring.application.name}") private String appName; @Inject @Resource(name = "redisTemplate") private ValueOperationsvalueOperations; @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()); }
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。