成人黄色在线网站 I 国产aa免费 I 中文字幕免费高清 I 国产三级影院 I 日韩欧美三级在线观看 I 久久久国产精品麻豆a片 I 欧美与黑人午夜性猛交久久久 I 91国产精品视频在线 I 国产美女狂喷水潮在线播放 I 黄页免费网站在线观看 I 欧美日韩激情视频 I 午夜理论无码片在线观看免费 I 深夜爽爽动态图无遮无挡 I 国精产品一区一区三区有限公司杨 I 天天操天天舔天天爽 I 免费看日本黄色片 I 成人va在线 I 日韩中文字幕在线观看 I 婷婷综合网 I 97视频免费观察看 I 色月丁香 I 日韩视频一二三 I 男女黄色毛片 I 美女疯狂连续喷潮视频 I 亚洲日本va一区二区sa I 欧美日韩视频区 I 毛片网在线 I 欧美一本在线 I 少妇一级淫片免费放香蕉 I avav在线看 I 久久精品亚洲中文字幕无码网站 I 天堂av在线中文在线新版 I 电影一区 电影二区 I 色av吧 中文字幕 I 国产精品伊人色

歡迎來到培訓無憂網!

全國切換

咨詢熱線 400-001-5729

位置:培訓無憂網 > 新聞資訊 > 電腦/IT > java培訓 >  Java學習分布式鎖的概念及使用目的解析

Java學習分布式鎖的概念及使用目的解析

來源:www.hebeijilong.cn 發布人:云朵

2022-01-07 11:10:51|已瀏覽:425次

Java學習分布式鎖的概念及使用目的解析

什么是分布式鎖?在回答這個問題之前,我們先回答一下什么是鎖。

      普通的鎖,即在單機多線程環境下,當多個線程需要訪問同一個變量或代碼片段時,被訪問的變量或代碼片段叫做臨界區域,我們需要控制線程一個一個的順序執行,否則會出現并發問題。

      如何控制呢?就是設置一個各個線程都能看的見的標志。然后,每個線程想訪問臨界區域時,都要先查看標志,如果標志沒有被占用,則說明目前沒有線程在訪問臨界區域。如果標志被占用了,則說明目前有線程正在訪問臨界區域,則當前線程需要等待。

      這個標志,就是鎖。

      在單機多線程的java程序中,我們可以使用堆內存中的變量作為標志,因為多線程是共享堆內存的,堆內存中的變量對于各個線程都是可見的。

      講明白了普通的鎖,接下來,我們再看看分布式鎖。

      在分布式環境下,即多臺計算機,每個計算機上會啟動jvm執行程序的運行環境下,如果不同計算機上的線程想訪問臨界區域時,該怎么辦呢?

      前面普通鎖的使用堆內存中的變量的方式肯定不適用了。因為在多機環境下,某臺計算機上的堆內存中的變量對于其他計算機上的線程肯定是不可見的。那么,根據鎖的本質和原理,我們就要找到另外的對于多機上的線程都可見的標志,以它來作為鎖,就可以了。這樣的鎖,就是分布式鎖。

      當然,這里只是解釋了什么是分布式鎖,至于分布式鎖該如何實現,其實有多重方式,關鍵在于要保證鎖對多機上的程序是可見的即可。一些常用的實現方式是,使用redis,使用數據庫等等。

為什么要使用分布式鎖?

      我們在開發應用的時候,如果需要對某一個共享變量進行多線程同步訪問的時候,可以使用我們學到的Java多線程的18般武藝進行處理,并且可以完美的運行,毫無Bug!

      注意這是單機應用,也就是所有的請求都會分配到當前服務器的JVM內部,然后映射為操作系統的線程進行處理!而這個共享變量只是在這個JVM內部的一塊內存空間!

      本文由培訓無憂網長沙牛耳教育專屬課程顧問整理發布,希望能夠對想參加長沙Java培訓班的學生有所幫助。更多Java培訓課程資訊歡迎關注培訓無憂網Java培訓頻道或添加老師微信:1503333605010

      注:尊重原創文章,轉載請注明出處和鏈接 http://www.hebeijilong.cn/news-id-13498.html 違者必究!部分文章來源于網絡由培訓無憂網編輯部人員整理發布,內容真實性請自行核實或聯系我們,了解更多相關資訊請關注java培訓頻道查看更多,了解相關專業課程信息您可在線咨詢也可免費申請試課。關注官方微信了解更多:150 3333 6050

留下你的信息,課程顧問老師會一對一幫助你規劃更適合你的專業課程!
  • 姓名:

  • 手機:

  • 地區:

  • 想學什么:

  • 培訓無憂網
免 費 申 請 試 聽
提交申請,《培訓無憂網》課程顧問老師會一對一幫助你規劃更適合你的專業課程!