目錄
Linux的幾種鎖定機制
互斥鎖和讀寫鎖的區別:
首頁 運維 linux運維 linux鎖有哪幾種

linux鎖有哪幾種

Jun 16, 2022 pm 07:20 PM

linux鎖的種類:1、mutex(互斥鎖),用來保證在任何時刻,都只能有一個執行緒存取該物件;2、rwlock(讀寫鎖),分為讀鎖和寫鎖,適用於讀取資料的頻率遠大於寫資料的頻率的場合;3、spinlock(自旋鎖),在任何時刻同樣只能有一個執行緒存取物件;4、seqlock(順序鎖),用於能夠區分讀與寫的場合,且是讀取操作很多、寫入操作很少,寫入操作的優先權大於讀取操作。

linux鎖有哪幾種

本教學操作環境: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中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Debian上Tigervnc的日誌在哪查看 Debian上Tigervnc的日誌在哪查看 Apr 13, 2025 am 07:24 AM

在Debian系統中,Tigervnc服務器的日誌文件通常存儲在用戶的home目錄下的.vnc文件夾內。如果您以特定用戶身份運行Tigervnc,那麼日誌文件名通常類似於xf:1.log,其中xf:1代表用戶名。要查看這些日誌,您可以使用以下命令:cat~/.vnc/xf:1.log或者,您可以使用文本編輯器打開日誌文件:nano~/.vnc/xf:1.log請注意,訪問和查看日誌文件可能需要root權限,這取決於系統的安全設置。

debian readdir如何與其他工具集成 debian readdir如何與其他工具集成 Apr 13, 2025 am 09:42 AM

Debian系統中的readdir函數是用於讀取目錄內容的系統調用,常用於C語言編程。本文將介紹如何將readdir與其他工具集成,以增強其功能。方法一:C語言程序與管道結合首先,編寫一個C程序調用readdir函數並輸出結果:#include#include#includeintmain(intargc,char*argv[]){DIR*dir;structdirent*entry;if(argc!=2){

如何解讀Debian Sniffer的輸出結果 如何解讀Debian Sniffer的輸出結果 Apr 12, 2025 pm 11:00 PM

DebianSniffer是一個網絡嗅探工具,用於捕獲和分析網絡數據包時間戳(Timestamp):顯示數據包捕獲的時間,通常以秒為單位。源IP地址(SourceIP):發送數據包的設備的網絡地址。目標IP地址(DestinationIP):接收數據包的設備的網絡地址。源端口(SourcePort):發送數據包的設備使用的端口號。目標端口(Destinatio

Linux體系結構:揭示5個基本組件 Linux體系結構:揭示5個基本組件 Apr 20, 2025 am 12:04 AM

Linux系統的五個基本組件是:1.內核,2.系統庫,3.系統實用程序,4.圖形用戶界面,5.應用程序。內核管理硬件資源,系統庫提供預編譯函數,系統實用程序用於系統管理,GUI提供可視化交互,應用程序利用這些組件實現功能。

Debian如何回收不再使用的包 Debian如何回收不再使用的包 Apr 13, 2025 am 08:51 AM

本文介紹如何在Debian系統中清理無用軟件包,釋放磁盤空間。第一步:更新軟件包列表確保你的軟件包列表是最新的:sudoaptupdate第二步:查看已安裝的軟件包使用以下命令查看所有已安裝的軟件包:dpkg--get-selections|grep-vdeinstall第三步:識別冗餘軟件包利用aptitude工具查找不再需要的軟件包。 aptitude會提供建議,幫助你安全地刪除軟件包:sudoaptitudesearch'~pimportant'此命令列出標記

關鍵Linux操作:初學者指南 關鍵Linux操作:初學者指南 Apr 09, 2025 pm 04:09 PM

Linux初學者應掌握文件管理、用戶管理和網絡配置等基本操作。 1)文件管理:使用mkdir、touch、ls、rm、mv、cp命令。 2)用戶管理:使用useradd、passwd、userdel、usermod命令。 3)網絡配置:使用ifconfig、echo、ufw命令。這些操作是Linux系統管理的基礎,熟練掌握它們可以有效管理系統。

Debian如何提升Hadoop數據處理速度 Debian如何提升Hadoop數據處理速度 Apr 13, 2025 am 11:54 AM

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

Debian郵件服務器DNS設置指南 Debian郵件服務器DNS設置指南 Apr 13, 2025 am 11:33 AM

要配置Debian郵件服務器的DNS設置,您可以按照以下步驟進行操作:打開網絡配置文件:使用文本編輯器(例如vi或nano)打開網絡配置文件/etc/network/interfaces。 sudonano/etc/network/interfaces查找網絡接口配置:在配置文件中找到要修改的網絡接口。通常情況下,以太網接口的配置位於ifaceeth0區塊中。

See all articles