linux鎖的種類:1、mutex(互斥鎖),用來保證在任何時刻,都只能有一個執行緒存取該物件;2、rwlock(讀寫鎖),分為讀鎖和寫鎖,適用於讀取資料的頻率遠大於寫資料的頻率的場合;3、spinlock(自旋鎖),在任何時刻同樣只能有一個執行緒存取物件;4、seqlock(順序鎖),用於能夠區分讀與寫的場合,且是讀取操作很多、寫入操作很少,寫入操作的優先權大於讀取操作。
本教學操作環境:linux7.3系統、Dell G3電腦。
Linux的幾種鎖定機制
互斥鎖:mutex
互斥鎖:mutex,用來保證在任何時刻,都只能有一個執行緒存取該物件。當取得鎖定操作失敗時,執行緒會進入睡眠,等待鎖定釋放時被喚醒。
讀寫鎖定:rwlock
讀寫鎖定:rwlock,分為讀鎖定和寫鎖定。處於讀取操作時,可以允許多個執行緒同時獲得讀取操作。但是同一時刻只能有一個執行緒可以獲得寫鎖。其它取得寫鎖失敗的執行緒都會進入睡眠狀態,直到寫鎖釋放時被喚醒。
注意:寫鎖定會阻塞其它讀寫鎖定。當有一個線程獲得寫鎖在寫時,讀鎖也不能被其它線程獲取;寫者優先於讀者(一旦有寫者,則後續讀者必須等待,喚醒時優先考慮寫者)。
- 適用於讀取資料的頻率遠大於寫入資料的頻率的場合。
自旋鎖定:spinlock
自旋鎖定:spinlock,在任何時刻同樣只能有一個執行緒存取物件。但是當獲取鎖定操作失敗時,不會進入睡眠,而是在原地自旋,直到鎖被釋放。這樣節省了執行緒從睡眠狀態到被喚醒期間的消耗,在加鎖時間短暫的環境下會極大的提高效率。但如果加鎖時間過長,則會非常浪費CPU資源。
RCU
RCU:即read-copy-update,在修改資料時,首先需要讀取數據,然後產生一個副本,對副本進行修改。修改完成後,再將舊資料update成新的資料。
使用RCU時,讀者幾乎不需要同步開銷,既不需要取得鎖,也不使用原子指令,不會導致鎖競爭,因此就不用考慮死鎖問題了。而對於寫者的同步開銷較大,它需要複製被修改的數據,也必須使用鎖定機制同步並行其它寫者的修改操作。在有大量讀取操作,少量寫入操作的情況下效率非常高。
信號量:semaphore
linux核心的信號量在概念和原理上與用戶態的SystemV的IPC機制信號量是一樣的,但是它絕不可能在核心之外使用,因此它與SystemV的IPC機制訊號量毫不相干。
信號量在創建時需要設定一個初始值,表示同時可以有幾個任務可以存取該信號量保護的共享資源,初始值為1就變成互斥鎖(Mutex),即同時只能有一個任務可以存取信號量保護的共享資源。一個任務要想存取共享資源,首先必須得到信號量,獲取信號量的操作將把信號量的值減1,若當前信號量的值為負數,表示無法獲得信號量,該任務必須掛起在該信號量的等待佇列等待該信號量可用;若目前信號量的值為非負數,表示可以獲得信號量,因而可以立刻存取被該信號量保護的共享資源。當任務存取完被信號量保護的共享資源後,必須釋放信號量,釋放信號量透過把信號量的值加1實現,如果信號量的值為非正數,表示有任務等待當前信號量,因此它也喚醒所有等待該信號量的任務。
rw_semaphore (讀寫訊號量)
讀寫信號量對訪問者進行了細分,或者為讀者,或者為寫者,讀者在保持讀寫信號量期間只能對該讀寫信號量保護的共享資源進行讀訪問,如果一個任務除了需要閱讀,可能還需要寫,那麼它必須被歸類為寫者,它在對共享資源訪問之前必須先獲得寫者身份,寫者在發現自己不需要寫訪問的情況下可以降級為讀者。讀寫信號量同時擁有的讀者數不受限制,也就說可以有任意多個讀者同時擁有一個讀寫信號量。如果一個讀寫信號量目前沒有被寫者擁有且也沒有寫者等待讀者釋放信號量,那麼任何讀者都可以成功獲得該讀寫信號量;否則,讀者必須被掛起直到寫者釋放該信號量。如果一個讀寫信號量目前沒有被讀者或寫者擁有並且也沒有寫者等待該信號量,那麼一個寫者可以成功獲得該讀寫信號量,否則寫者將被掛起,直到沒有任何訪問者。因此,寫者是排他性的,獨佔性的。
讀寫信號量有兩種實現,一種是通用的,不依賴硬體架構,因此,增加新的架構不需要重新實現它,但缺點是性能低,獲得和釋放讀寫信號量的開銷大;另一種是架構相關的,因此效能高,取得和釋放讀寫訊號量的開銷小,但增加新的架構需要重新實作。在核心配置時,可以透過選項去控制使用哪一種實作。
讀寫信號量:rw_semaphore
讀寫信號量對訪問者進行了細分,或者為讀者,或者為寫者,讀者在保持讀寫信號量期間只能對該讀寫信號量保護的共享資源進行讀取訪問,如果一個任務除了需要讀,可能還需要寫,那麼它必須被歸類為寫者,它在對共享資源訪問之前必須先獲得寫者身份,寫者在發現自己不需要寫訪問的情況下可以降級為讀者。讀寫信號量同時擁有的讀者數不受限制,也就說可以有任意多個讀者同時擁有一個讀寫信號量。如果一個讀寫信號量目前沒有被寫者擁有且也沒有寫者等待讀者釋放信號量,那麼任何讀者都可以成功獲得該讀寫信號量;否則,讀者必須被掛起直到寫者釋放該信號量。如果一個讀寫信號量目前沒有被讀者或寫者擁有並且也沒有寫者等待該信號量,那麼一個寫者可以成功獲得該讀寫信號量,否則寫者將被掛起,直到沒有任何訪問者。因此,寫者是排他性的,獨佔性的。
讀寫信號量有兩種實現,一種是通用的,不依賴硬體架構,因此,增加新的架構不需要重新實現它,但缺點是性能低,獲得和釋放讀寫信號量的開銷大;另一種是架構相關的,因此性能高,獲取和釋放讀寫信號量的開銷小,但增加新的架構需要重新實現。在核心配置時,可以透過選項去控制使用哪一種實作。
seqlock****(順序鎖定)
用於能夠區分讀取與寫入的場合,並且是讀取操作很多、寫入操作很少,寫入操作的優先權大於讀取操作。 seqlock的實作想法是,用一個遞增的整數數來表示sequence。寫入操作進入臨界區時,sequence ;退出臨界區時,sequence再 。
寫入作業還需要取得一個鎖(例如mutex),這個鎖僅用於寫寫互斥,以確保同一時間最多只有一個正在進行的寫入操作。當sequence為奇數時,表示有寫入操作正在進行,這時讀取操作要進入臨界區需要等待,直到sequence變成偶數。讀取操作進入臨界區時,需要記錄下當前sequence的值,等它退出臨界區的時候用記錄的sequence與當前sequence做比較,不相等則表示在讀操作進入臨界區期間發生了寫入操作,這時候讀操作讀到的東西是無效的,需要回傳重試。
seqlock寫寫是必須要互斥的。但是seqlock的應用程式場景本身就是讀多寫少的情況,寫衝突的機率是很低的。所以這裡的寫寫互斥基本上不會有什麼效能損失。而讀寫操作是不需要互斥的。 seqlock的應用程式場景是寫入操作優先於讀取操作,對於寫入操作來說,幾乎是沒有阻塞的(除非發生寫寫衝突這一小機率事件),只需要做sequence 這個附加動作。而讀取操作也不需要阻塞,只是當發現讀寫衝突時需要retry。 seqlock的一個典型應用是時鐘的更新,系統中每1毫秒會有一個時鐘中斷,對應的中斷處理程序會更新時鐘(寫入操作)。
而使用者程式可以呼叫gettimeofday之類的系統呼叫來取得目前時間(讀取操作)。在這種情況下,使用seqlock可以避免過多的gettimeofday系統呼叫把中斷處理程序給阻塞了(如果使用讀寫鎖,而不用seqlock的話就會這樣)。中斷處理程序總是優先的,如果gettimeofday系統呼叫與之衝突了,那麼用戶程式多等等也無妨。
互斥鎖和讀寫鎖的區別:
1)讀寫鎖定區分讀者和寫者,而互斥鎖不區分
2)互斥鎖同一時間只允許一個執行緒存取該對象,無論讀寫;讀寫鎖同一時間內只允許一個寫者,但是允許多個讀者同時讀取對象。
相關推薦:《Linux影片教學》
以上是linux鎖有哪幾種的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Linux系統管理和維護的關鍵步驟包括:1)掌握基礎知識,如文件系統結構和用戶管理;2)進行系統監控與資源管理,使用top、htop等工具;3)利用系統日誌進行故障排查,借助journalctl等工具;4)編寫自動化腳本和任務調度,使用cron工具;5)實施安全管理與防護,通過iptables配置防火牆;6)進行性能優化與最佳實踐,調整內核參數和養成良好習慣。

Linux維護模式通過在啟動時添加init=/bin/bash或single參數進入。 1.進入維護模式:編輯GRUB菜單,添加啟動參數。 2.重新掛載文件系統為讀寫模式:mount-oremount,rw/。 3.修復文件系統:使用fsck命令,如fsck/dev/sda1。4.備份數據並謹慎操作,避免數據丟失。

本文探討如何在Debian系統上提升Hadoop數據處理效率。優化策略涵蓋硬件升級、操作系統參數調整、Hadoop配置修改以及高效算法和工具的運用。一、硬件資源強化確保所有節點硬件配置一致,尤其關注CPU、內存和網絡設備性能。選擇高性能硬件組件對於提升整體處理速度至關重要。二、操作系統調優文件描述符和網絡連接數:修改/etc/security/limits.conf文件,增加系統允許同時打開的文件描述符和網絡連接數上限。 JVM參數調整:在hadoop-env.sh文件中調整

本指南將指導您學習如何在Debian系統中使用Syslog。 Syslog是Linux系統中用於記錄系統和應用程序日誌消息的關鍵服務,它幫助管理員監控和分析系統活動,從而快速識別並解決問題。一、Syslog基礎知識Syslog的核心功能包括:集中收集和管理日誌消息;支持多種日誌輸出格式和目標位置(例如文件或網絡);提供實時日誌查看和過濾功能。二、安裝和配置Syslog(使用Rsyslog)Debian系統默認使用Rsyslog。您可以通過以下命令安裝:sudoaptupdatesud

選擇適合Debian系統的Hadoop版本,需要綜合考慮以下幾個關鍵因素:一、穩定性與長期支持:對於追求穩定性和安全性的用戶,建議選擇Debian穩定版,例如Debian11(Bullseye)。該版本經過充分測試,擁有長達五年的支持週期,能夠確保系統穩定運行。二、軟件包更新速度:如果您需要使用最新的Hadoop功能和特性,則可以考慮Debian的不穩定版(Sid)。但需注意,不穩定版可能存在兼容性問題和穩定性風險。三、社區支持與資源:Debian擁有龐大的社區支持,可以提供豐富的文檔和

本文介紹如何在Debian系統上使用TigerVNC共享文件。你需要先安裝TigerVNC服務器,然後進行配置。一、安裝TigerVNC服務器打開終端。更新軟件包列表:sudoaptupdate安裝TigerVNC服務器:sudoaptinstalltigervnc-standalone-servertigervnc-common二、配置TigerVNC服務器設置VNC服務器密碼:vncpasswd啟動VNC服務器:vncserver:1-localhostno

配置Debian郵件服務器的防火牆是確保服務器安全性的重要步驟。以下是幾種常用的防火牆配置方法,包括iptables和firewalld的使用。使用iptables配置防火牆安裝iptables(如果尚未安裝):sudoapt-getupdatesudoapt-getinstalliptables查看當前iptables規則:sudoiptables-L配置

在Debian郵件服務器上安裝SSL證書的步驟如下:1.安裝OpenSSL工具包首先,確保你的系統上已經安裝了OpenSSL工具包。如果沒有安裝,可以使用以下命令進行安裝:sudoapt-getupdatesudoapt-getinstallopenssl2.生成私鑰和證書請求接下來,使用OpenSSL生成一個2048位的RSA私鑰和一個證書請求(CSR):openss


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。