詳解Linux文件鎖flock
在多個進程同時操作同一份文件的過程中,很容易導致文件中的數(shù)據(jù)混亂,需要鎖操作來保證數(shù)據(jù)的完整性,這里介紹的針對文件的鎖,稱之為“文件鎖”-flock。
flock,建議性鎖,不具備強制性。一個進程使用flock將文件鎖住,另一個進程可以直接操作正在被鎖的文件,修改文件中的數(shù)據(jù),原因在于flock只是用于檢測文件是否被加鎖,針對文件已經(jīng)被加鎖,另一個進程寫入數(shù)據(jù)的情況,內(nèi)核不會阻止這個進程的寫入操作,也就是建議性鎖的內(nèi)核處理策略。
flock主要三種操作類型:
- LOCK_SH,共享鎖,多個進程可以使用同一把鎖,常被用作讀共享鎖;
- LOCK_EX,排他鎖,同時只允許一個進程使用,常被用作寫鎖;
- LOCK_UN,釋放鎖;
進程使用flock嘗試鎖文件時,如果文件已經(jīng)被其他進程鎖住,進程會被阻塞直到鎖被釋放掉,或者在調(diào)用flock的時候,采用LOCK_NB參數(shù),在嘗試鎖住該文件的時候,發(fā)現(xiàn)已經(jīng)被其他服務鎖住,會返回錯誤,errno錯誤碼為EWOULDBLOCK。即提供兩種工作模式:阻塞與非阻塞類型。
服務會阻塞等待直到鎖被釋放:
flock(lockfd,LOCK_EX)
服務會返回錯誤發(fā)現(xiàn)文件已經(jīng)被鎖住時:
ret = flock(lockfd,LOCK_EX|LOCK_NB)
同時ret = -1, errno = EWOULDBLOCK
flock鎖的釋放非常具有特色,即可調(diào)用LOCK_UN參數(shù)來釋放文件鎖,也可以通過關閉fd的方式來釋放文件鎖(flock的第一個參數(shù)是fd),意味著flock會隨著進程的關閉而被自動釋放掉。
flock其中的一個使用場景為:檢測進程是否已經(jīng)存在;
int checkexit(char* pfile) { if (pfile == NULL) { return -1; } int lockfd = open(pfile,O_RDWR); if (lockfd == -1) { return -2; } int iret = flock(lockfd,LOCK_EX|LOCK_NB); if (iret == -1) { return -3; } return 0; }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
CentOS系統(tǒng)下Apache配置多域名或多端口映射的方法
我們大多情況是一臺服務器一個IP,這樣配置起來很簡單,但是如何想多域名多端口映射的話就沒那么簡單了,下面這篇文章主要介紹了CentOS系統(tǒng)下Apache配置多域名或多端口映射的方法,需要的朋友可以參考學習,下面來一起看看吧。2016-12-12Ubuntu16.04搭建php5.6Web服務器環(huán)境
今天小編就為大家分享一篇關于Ubuntu16.04搭建php5.6Web服務器環(huán)境,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03linux用戶和組命令實例分析【切換、添加用戶、權限控制等】
這篇文章主要介紹了linux用戶和組命令,結合實例形式分析了Linux系統(tǒng)切換、添加用戶、權限控制等相關命令與使用技巧,需要的朋友可以參考下2020-03-03linux下使用 du查看某個文件或目錄占用磁盤空間的大小方法
下面小編就為大家?guī)硪黄猯inux下使用 du查看某個文件或目錄占用磁盤空間的大小方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11