久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Python中使用threading.Event協調線程的運行詳解

瀏覽:41日期:2022-07-26 16:51:52

threading.Event機制類似于一個線程向其它多個線程發(fā)號施令的模式,其它線程都會持有一個threading.Event的對象,這些線程都會等待這個事件的“發(fā)生”,如果此事件一直不發(fā)生,那么這些線程將會阻塞,直至事件的“發(fā)生”。

對此,我們可以考慮一種應用場景(僅僅作為說明),例如,我們有多個線程從Redis隊列中讀取數據來處理,這些線程都要嘗試去連接Redis的服務,一般情況下,如果Redis連接不成功,在各個線程的代碼中,都會去嘗試重新連接。

如果我們想要在啟動時確保Redis服務正常,才讓那些工作線程去連接Redis服務器,那么我們就可以采用threading.Event機制來協調各個工作線程的連接操作:

主線程中會去嘗試連接Redis服務,如果正常的話,觸發(fā)事件,各工作線程會嘗試連接Redis服務。

為此,我們可以寫下如下的程序:

import threadingimport timeimport logging logging.basicConfig(level=logging.DEBUG, format=’(%(threadName)-10s) %(message)s’,) def worker(event): logging.debug(’Waiting for redis ready...’) event.wait() logging.debug(’redis ready, and connect to redis server and do some work [%s]’, time.ctime()) time.sleep(1) readis_ready = threading.Event()t1 = threading.Thread(target=worker, args=(readis_ready,), name=’t1’)t1.start() t2 = threading.Thread(target=worker, args=(readis_ready,), name=’t2’)t2.start() logging.debug(’first of all, check redis server, make sure it is OK, and then trigger the redis ready event’)time.sleep(3) # simulate the check progress readis_ready.set()

運行這個程序:

(t1 ) Waiting for redis ready...(t2 ) Waiting for redis ready...(MainThread) first of all, check redis server, make sure it is OK, and then trigger the redis ready event(t2 ) redis ready, and connect to redis server and do some work [Wed Nov 5 12:45:03 2014](t1 ) redis ready, and connect to redis server and do some work [Wed Nov 5 12:45:03 2014]

t1和t2線程開始的時候都阻塞在等待redis服務器啟動的地方,一旦主線程確定了redis服務器已經正常啟動,那么會觸發(fā)redis_ready事件,各個工作線程就會去連接redis去做相應的工作。

threading.Event的wait方法還接受一個超時參數,默認情況下如果事件一直沒有發(fā)生,wait方法會一直阻塞下去,而加入這個超時參數之后,如果阻塞時間超過這個參數設定的值之后,wait方法會返回。

對應于上面的應用場景,如果Redis服務器一致沒有啟動,我們希望子線程能夠打印一些日志來不斷地提醒我們當前沒有一個可以連接的Redis服務,我們就可以通過設置這個超時參數來達成這樣的目的:

import threadingimport timeimport logging logging.basicConfig(level=logging.DEBUG, format=’(%(threadName)-10s) %(message)s’,) def worker(event): while not event.is_set(): logging.debug(’Waiting for redis ready...’) event.wait(1) logging.debug(’redis ready, and connect to redis server and do some work [%s]’, time.ctime()) time.sleep(1) readis_ready = threading.Event()t1 = threading.Thread(target=worker, args=(readis_ready,), name=’t1’)t1.start() t2 = threading.Thread(target=worker, args=(readis_ready,), name=’t2’)t2.start() logging.debug(’first of all, check redis server, make sure it is OK, and then trigger the redis ready event’)time.sleep(3) # simulate the check progress readis_ready.set()

與前面的無限阻塞版本唯一的不同就是,我們在工作線程中加入了一個while循環(huán),直到redis_ready事件觸發(fā)之后才會結束循環(huán),wait方法調用會在1秒的超時后返回,這樣,我們就可以看到各個工作線程在系統啟動的時候等待redis_ready的同時,會記錄一些狀態(tài)信息。

以下是這個程序的運行結果:

(t1 ) Waiting for redis ready...(t2 ) Waiting for redis ready...(MainThread) first of all, check redis server, make sure it is OK, and then trigger the redis ready event(t2 ) Waiting for redis ready...(t1 ) Waiting for redis ready...(t2 ) Waiting for redis ready...(t1 ) Waiting for redis ready...(t2 ) redis ready, and connect to redis server and do some work [Wed Nov 5 13:55:46 2014](t1 ) redis ready, and connect to redis server and do some work [Wed Nov 5 13:55:46 2014]

這樣,我們就可以在等待Redis服務啟動的同時,看到工作線程里正在等待的情況。

以上這篇Python中使用threading.Event協調線程的運行詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产一区二区三区久久久 | 久久中文字幕视频 | 久久免费福利视频 | 在线免费观看羞羞视频 | 久久伊人av | 久久久久久久久久久久久久av | 五月天婷婷国产精品 | 91久久久久久久久 | 一级毛片久久久 | 中文精品在线 | 一级一级一级毛片 | 日本一区二区三区四区不卡视频 | 欧美一区二区免费 | 超碰人人干 | 国产精品无码久久久久 | 国产在线小视频 | 亚洲精品3区 | 久久久资源 | 中文字幕一二区 | 一区二区中文 | 性高湖久久久久久久久aaaaa | 在线免费色视频 | 999精品嫩草久久久久久99 | 中国黄色在线视频 | 在线区 | 一区二区在线视频 | 在线手机电影 | 午夜精品久久久久99蜜 | 日韩精品一区二区三区在线播放 | 国产成人高清 | 黄色免费成人 | 亚洲第一免费看片 | 亚洲男人天堂2023 | 日本一区二区中文字幕 | 国产欧美日韩一区 | 亚洲欧美在线综合 | 中文在线a在线 | 欧美一区三区 | 9191视频 | 自拍视频在线观看 | 午夜欧美一区二区三区在线播放 |