Java基于redis實(shí)現(xiàn)分布式鎖的方法-創(chuàng)新互聯(lián)

這篇文章主要講解了Java基于redis實(shí)現(xiàn)分布式鎖的方法,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

我們提供的服務(wù)有:網(wǎng)站建設(shè)、成都網(wǎng)站制作、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、威信ssl等。為近千家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的威信網(wǎng)站制作公司

為什么會(huì)有這個(gè)需求:

例如一個(gè)簡(jiǎn)單用戶的操作,一個(gè)線程去修改用戶狀態(tài),首先在在內(nèi)存中讀出用戶的狀態(tài),然后在內(nèi)存中進(jìn)行修改,然后在存到數(shù)據(jù)庫(kù)中。在單線程中,這是沒(méi)有問(wèn)題的。但是在多線程中由于讀取,修改,寫(xiě)入是三個(gè)操作,不是原子操作(同時(shí)成功或失?。?,因此在多線程中會(huì)存在數(shù)據(jù)的安全性問(wèn)題。

這個(gè)問(wèn)題的話,就可以用分布式鎖在限制程序的并發(fā)執(zhí)行。

實(shí)現(xiàn)思路:

就是進(jìn)來(lái)一個(gè)先占位,當(dāng)別的線程進(jìn)來(lái)操作的時(shí)候,發(fā)現(xiàn)有人占位了,就會(huì)放棄或者稍后再試。

占位的實(shí)現(xiàn):

在redis中的setnx命令來(lái)實(shí)現(xiàn),redis命令可以參考我這篇博客https://www.cnblogs.com/javazl/p/12657280.html,默認(rèn)set命令就是存值,當(dāng)key存在的時(shí)候,set就會(huì)覆蓋key的value值,而setnx則不會(huì)。當(dāng)沒(méi)有key的時(shí)候,setnx就會(huì)進(jìn)來(lái)先占位,當(dāng)key存在了,其他的setnx就進(jìn)不來(lái)了。。等到第一個(gè)執(zhí)行完成后,在del命令釋放位子。

代碼實(shí)現(xiàn):

public class LockTest {
  public static void main(String[] args) {
    Redis redis = new Redis();
    redis.execute(jedis->{
      Long setnx = jedis.setnx("k1", "v1");
     //setnx的返回值為long類(lèi)型
      if (setnx == 1) {
        //沒(méi)人占位
        jedis.set("name", "zl");
        String name = jedis.get("name");
        System.out.println(name);
        //釋放資源
         jedis.del("k1");
      }else{
        //有人占位,停止/暫緩 操作
      }
    });
  }
}

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站bm7419.com,海內(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ì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

新聞標(biāo)題:Java基于redis實(shí)現(xiàn)分布式鎖的方法-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://bm7419.com/article40/didpeo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作品牌網(wǎng)站制作、企業(yè)網(wǎng)站制作微信公眾號(hào)、域名注冊(cè)網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作