Python簡單進(jìn)程鎖代碼實例
先說說線程
在多線程中,為了保證共享資源的正確性,我們常常會用到線程同步技術(shù).
將一些敏感操作變成原子操作,保證同一時刻多個線程中只有一個線程在執(zhí)行這個原子操作。
我最常用的是互斥鎖,也稱獨占鎖。其次還有讀寫鎖,信號量,條件變量等。
除此之外,我們在進(jìn)程間通信時會用到信號,向某一個進(jìn)程發(fā)送信號,該進(jìn)程中設(shè)置信號處理函數(shù),然后當(dāng)該進(jìn)程收到信號時,執(zhí)行某些操作。
其實在線程中,也可以接受信號,利用這種機(jī)制,我們也可以用來實現(xiàn)線程同步。更多信息見 http://www.dhdzp.com/article/64977.htm
再說說進(jìn)程
進(jìn)程里我們通過一些進(jìn)程間通信方式,可以實現(xiàn)進(jìn)程間的同步。
最近我遇到的一個情況是,某采集系統(tǒng)進(jìn)程池中很多進(jìn)程會向同一個日志文件中打印日志,如果通過進(jìn)程間通信實現(xiàn),比較麻煩。
還有一種辦法,如果采用共享內(nèi)存的方式,不同的進(jìn)程分別將日志消息通過共享內(nèi)存放入一個線程安全的隊列中,再建立一個進(jìn)程負(fù)責(zé)專門打印日志,這樣也可以保證不被大亂,
保證日志的正確性,但代碼量也很多阿。
還有一種辦法,在共享內(nèi)存中設(shè)置一個互斥鎖,所有進(jìn)程共享。
如果能像線程一樣,有一個簡單的互斥鎖,用的時候只要加鎖,就能實現(xiàn)進(jìn)程間的互斥就好了。之前對文件加鎖,也有些印象,于是我用它實現(xiàn)了一個進(jìn)程間的互斥鎖
#coding=utf-8
"""
Process mutex lock.
Actually it is implemented by file lock.
"""
import fcntl
class ProcessLock(object):
__lockfd = None
@staticmethod
def lock():
ProcessLock.__lockfd = open(__file__, 'a+')
fcntl.flock(ProcessLock.__lockfd, fcntl.LOCK_EX)
@staticmethod
def unlock():
fcntl.flock(ProcessLock.__lockfd, fcntl.LOCK_UN)
加鎖 ProcessLock.lock()
釋放 ProcessLock.unlock()
非常簡單使用,有興趣的朋友可以試一試。
相關(guān)文章
Pycharm插件(Grep Console)自定義規(guī)則輸出顏色日志的方法
這篇文章主要介紹了Pycharm插件(Grep Console)自定義規(guī)則輸出顏色日志的方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05
Python編程之字符串模板(Template)用法實例分析
這篇文章主要介紹了Python編程之字符串模板(Template)用法,結(jié)合具體實例形式分析了Python字符串模板的功能、定義與使用方法,需要的朋友可以參考下2017-07-07
Django實現(xiàn)WebSocket在線聊天室功能(channels庫)
本文基于channels庫Django實現(xiàn)WebSocket在線聊天室功能,包括安裝及創(chuàng)建django項目的全過程,通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
python實現(xiàn)兩個經(jīng)緯度點之間的距離和方位角的方法
今天小編就為大家分享一篇python實現(xiàn)兩個經(jīng)緯度點之間的距離和方位角的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
用Python selenium實現(xiàn)淘寶搶單機(jī)器人
今天給大家?guī)淼氖顷P(guān)于Python實戰(zhàn)的相關(guān)知識,文章圍繞著用Python selenium實現(xiàn)淘寶搶單機(jī)器人展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06

