麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Linux Shell > 正文

shell腳本實現文件鎖功能

2020-07-27 19:11:44
字體:
來源:轉載
供稿:網友

1.背景

當多個進程可能會對同樣的數據執行操作時,這些進程需要保證其它進程沒有在操作,以免損壞數據。通常,這樣的進程會使用一個“鎖文件”,也就是建立一個文件來告訴別的進程自己在運行,如果檢測到那個文件存在則認為有操作同樣數據的進程在工作。這樣的問題是,進程不小心意外死亡了,沒有清理掉那個鎖文件,那么只能由用戶手動來清理了。

2.關于flock

flock 是對于整個文件的建議性鎖。也就是說,如果一個進程在一個文件(inode)上放了鎖,那么其它進程是可以知道的。(建議性鎖不強求進程遵守。)最棒的一點是,它的第一個參數是文件描述符,在此文件描述符關閉時,鎖會自動釋放。而當進程終止時,所有的文件描述符均會被關閉。

3. shell中實現flock系統調用的命令是flock,其使用格式有以下兩種(man flock)


復制代碼 代碼如下:

flock [-sxon] [-w timeout] lockfile [-c] command...
flock [-sxun] [-w timeout] fd


選項和參數:


-s,--shared:獲取一個共享鎖,在定向為某文件的FD上設置共享鎖而未釋放鎖的時間內,其他進程試圖在定向為此文件的FD上設置獨占鎖的請求失敗,而其他進程試圖在定向為此文件的FD上設置共享鎖的請求會成功。
-x,-e,--exclusive:獲取一個排它鎖,或者稱為寫入鎖,為默認項
-u,--unlock:手動釋放鎖,一般情況不必須,當FD關閉時,系統會自動解鎖,此參數用于腳本命令一部分需要異步執行,一部分可以同步執行的情況。
-n,--nb, --nonblock:非阻塞模式,當獲取鎖失敗時,返回1而不是等待
-w, --wait, --timeout seconds:設置阻塞超時,當超過設置的秒數時,退出阻塞模式,返回1,并繼續執行后面的語句
-o, --close:表示當執行command前關閉設置鎖的FD,以使command的子進程不保持鎖。
-c, --command command:在shell中執行其后的語句

4. shell中實現排它鎖避免腳本重復執行

Linux中的例行性工作排程crontab會定時執行一些腳本,但腳本的執行時間往往無法控制,當腳本執行時間過長時,可能會導致上一次任務的腳本還沒執行完,下一次任務的腳本又開始執行了。這種情況下可能會出現一些并發問題,嚴重時會導致出現臟數據/性能瓶頸的惡性循環。
通過使用flock建立排它鎖可以規避這個問題,如果一個進程對某個加了排他鎖,則其它進程無法加鎖,可以選擇等待超時或馬上返回。測試實例如下:

4.1 創建執行腳本

復制代碼 代碼如下:

#cat /scripts/shell/file_lock.sh
#!/bin/bash
# Description: test for file flock
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH

echo ""
echo "----------------------------------"

echo "start at `date '+%Y-%m-%d %H:%M:%S'` ..."

sleep 140s

echo "finished at `date '+%Y-%m-%d %H:%M:%S'` ..."


4.2 創建定時任務:測試排它鎖


復制代碼 代碼如下:

#crontab -e
* * * * * flock -xn /dev/shm/test.lock -c "sh /scripts/shell/file_lock.sh > /root/stdout.log"

每分鐘執行一次該腳本,并將輸出信息寫入到stdout.log
 
查看輸出日志如下:
復制代碼 代碼如下:

----------------------------------
start at 2014-04-10 10:23:01 ...            #獲取鎖
finish at 2014-04-10 10:25:21 ...           #釋放鎖
 
 
----------------------------------
start at 2014-04-10 10:26:01 ...            #10:27:00及10:28:00啟動的定時任務由于無法獲取鎖,以失敗而退出執行,直到10:26:00才獲取到鎖
finish at 2014-04-10 10:28:21 ...


4.3 測試排它鎖,加上等待超時


復制代碼 代碼如下:

* * * * * flock -x -w 20 /dev/shm/test.lock -c "sh /scripts/shell/file_lock.sh > /root/stdout.log"

查看日志輸出信息:
復制代碼 代碼如下:

----------------------------------
start at 2014-04-10 10:29:01 ...
finish at 2014-04-10 10:31:21 ...
 
----------------------------------
start at 2014-04-10 10:31:21 ...    #10:31:00啟動的定時任務等待了20秒后,上一個任務釋放了鎖,所以此任務可以馬上拿到鎖,并繼續執行
finish at 2014-04-10 10:33:41 ...

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲一区二区成人 | 国产免费看 | 成人毛片视频在线观看 | 91av资源在线 | 九九热这里只有精品8 | 亚洲精品欧美二区三区中文字幕 | 久草在线看片 | 特级黄毛片 | 亚洲国产精品高潮呻吟久久 | 男女羞羞的视频 | av电影在线观看网址 | 97青青草视频 | 久久tv免费国产高清 | 精品一区二区三区中文字幕老牛 | 亚洲激情91| 九九色网站 | 91精品国产91久久久久久 | 日韩专区在线 | 国产精品一区二区三区99 | 极品销魂一区二区三区 | 日本网站一区二区三区 | 操毛片 | 91成人一区二区三区 | 小情侣嗯啊哦视频www | 永久久久 | 91久久在线观看 | 91美女啪啪 | 全免费午夜一级毛片真人 | 天天夜天天操 | 国产一区二区三区视频在线 | 日本成人一区二区 | 成人不卡一区二区 | 亚洲性生活视频 | 在线观看免费av网 | 美女黄网站免费观看 | 国产精品成人一区二区三区吃奶 | 久久av一区二区 | 精品一区二区视频在线观看 | 他也色在线视频 | 免费在线观看成年人视频 | 日本成人一区二区 |