溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么用數(shù)據(jù)庫(kù)的悲觀鎖來(lái)實(shí)現(xiàn)一個(gè)分布式的鎖

發(fā)布時(shí)間:2022-01-15 10:11:47 來(lái)源:億速云 閱讀:216 作者:iii 欄目:云計(jì)算

這篇“怎么用數(shù)據(jù)庫(kù)的悲觀鎖來(lái)實(shí)現(xiàn)一個(gè)分布式的鎖”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“怎么用數(shù)據(jù)庫(kù)的悲觀鎖來(lái)實(shí)現(xiàn)一個(gè)分布式的鎖”文章吧。

分布式鎖顧名思義是發(fā)生在分布式環(huán)境中的。對(duì)于單進(jìn)程場(chǎng)景,我們可以使用語(yǔ)言和類庫(kù)提供的鎖,對(duì)于分布式鎖,我也可以使用分布式鎖。也就是說(shuō)同樣的鎖使用的環(huán)境不同,分布式環(huán)境中用的鎖就叫分布式鎖!

根據(jù)上面的理解,分布式鎖是不是應(yīng)該具備下面的特點(diǎn):

  1. 分布式鎖必須保證在分布式部署的應(yīng)用集群中,同一個(gè)方法在同一時(shí)間只能被一臺(tái)機(jī)器上的一個(gè)線程執(zhí)行;

  2. 一個(gè)線程獲得了鎖,其他線程必須等待持有鎖的線程釋放掉才能再獲??;

  3. 鎖必須要有超時(shí)機(jī)制(避免死鎖)

基于上面的特點(diǎn),我們就可以通過(guò)數(shù)據(jù)庫(kù)的悲觀鎖來(lái)實(shí)現(xiàn)一個(gè)分布式鎖。

代碼非常的簡(jiǎn)單,使用 for update 即可。具體如下:

public class XttblogLock {

   private DataSource dataSource;

   private static final String cmd = "select * from xttblog_lock where id = 1 for update";

   public XttblogLock(DataSource ds) {
       this.dataSource = ds;
   }

   public static interface CallBack{
       public void doAction();
   }
   public void lock(CallBack callBack)  {
       Connection conn = null;
       PreparedStatement stmt = null;
       ResultSet rs = null;

       try {
           //try get lock
           System.out.println(Thread.currentThread().getName() + " begin try lock");
           conn = dataSource.getConnection();
           conn.setAutoCommit(false);
           stmt = conn.prepareStatement(cmd);
           rs = stmt.executeQuery();
         
           //do business thing
           callBack.doAction();
           
           //release lock
           conn.commit();
           System.out.println(Thread.currentThread().getName() + " release lock");

       } catch (SQLException e) {
           e.printStackTrace();

       } finally {
           
           if (null != conn) {
               try {
                   conn.close();
               } catch (SQLException e) {
                   e.printStackTrace();
               }
           }

       }
   }
}
 

該鎖的調(diào)用也非常的簡(jiǎn)單,具體代碼如下:使用數(shù)據(jù)庫(kù)悲觀鎖實(shí)現(xiàn)分布式鎖主要用了數(shù)據(jù)庫(kù)的 for update 命令,執(zhí)行改命令后,對(duì)應(yīng)行記錄會(huì)被鎖住,其它線程會(huì)被阻塞主,直到獲取到這行記錄的線程提交了事務(wù)。這里需要注意要把自動(dòng)提交設(shè)置為 false。

該鎖的調(diào)用也非常的簡(jiǎn)單,具體代碼如下:

final XttblogLock xttblogLock = new XttblogLock(dataSource);
xttblogLock.lock(new CallBack() {
                       
   @Override
   public void doAction() {
       System.out.println(Thread.currentThread().getName() + "beging do somthing");
       try {
           System.out.println("業(yè)余草:www.xttblog.com 歡迎你!");
           Thread.sleep(2000);
       } catch (InterruptedException e) {
           e.printStackTrace();
       }
       System.out.println(Thread.currentThread().getName() + "end do somthing");

   }
});

雖然數(shù)據(jù)庫(kù)的 for update 悲觀鎖可以用來(lái)做分布式鎖,但實(shí)際的生產(chǎn)過(guò)程中采用這種方法的非常少,因?yàn)樗阅懿皇呛芨摺?/p>

以上就是關(guān)于“怎么用數(shù)據(jù)庫(kù)的悲觀鎖來(lái)實(shí)現(xiàn)一個(gè)分布式的鎖”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI