文章詳情頁
python - 如何解決queue中同一個參數(shù)被多個線程同時調(diào)用?
瀏覽:138日期:2022-08-18 15:18:47
問題描述
本人想實現(xiàn)一個基礎(chǔ)的多線程爬蟲,初步想法是篩選目錄中多個電影標題是否有關(guān)鍵字,沒有的話就進入到詳情頁中查找電影類別中是否有關(guān)鍵字。下面是一部分代碼:
executor = ThreadPoolExecutor(max_workers=5) #Future模塊的多線程executor.map(get_page,whole) #get_page()為篩選標題的函數(shù)time.sleep(5)while not que.empty(): que_data = que.get() filter(que_data) #filter()為篩選分類關(guān)鍵字的函數(shù),但每次五個線程同時訪問同一個url
但現(xiàn)在每次多個線程同時調(diào)用queue中的同一個url,請問有什么解決辦法嗎
問題解答
回答1:專門用一個線程讀取queue中的url,然后分配給某個線程
對該queue的訪問加鎖
相關(guān)文章:
1. 關(guān)于docker下的nginx壓力測試2. angular.js使用$resource服務把數(shù)據(jù)存入mongodb的問題。3. angular.js - angularjs的自定義過濾器如何給文字加顏色?4. docker-machine添加一個已有的docker主機問題5. 為什么我ping不通我的docker容器呢???6. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.7. docker - 如何修改運行中容器的配置8. nignx - docker內(nèi)nginx 80端口被占用9. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題10. docker鏡像push報錯
排行榜

熱門標簽