文章詳情頁
python - 如何解決queue中同一個參數被多個線程同時調用?
瀏覽:148日期:2022-08-18 15:18:47
問題描述
本人想實現一個基礎的多線程爬蟲,初步想法是篩選目錄中多個電影標題是否有關鍵字,沒有的話就進入到詳情頁中查找電影類別中是否有關鍵字。下面是一部分代碼:
executor = ThreadPoolExecutor(max_workers=5) #Future模塊的多線程executor.map(get_page,whole) #get_page()為篩選標題的函數time.sleep(5)while not que.empty(): que_data = que.get() filter(que_data) #filter()為篩選分類關鍵字的函數,但每次五個線程同時訪問同一個url
但現在每次多個線程同時調用queue中的同一個url,請問有什么解決辦法嗎
問題解答
回答1:專門用一個線程讀取queue中的url,然后分配給某個線程
對該queue的訪問加鎖
相關文章:
1. docker不顯示端口映射呢?2. docker內創建jenkins訪問另一個容器下的服務器問題3. vim - docker中新的ubuntu12.04鏡像,運行vi提示,找不到命名.4. docker-compose 為何找不到配置文件?5. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?6. debian - docker依賴的aufs-tools源碼哪里可以找到啊?7. docker gitlab 如何git clone?8. mac連接阿里云docker集群,已經卡了2天了,求問?9. docker-compose中volumes的問題10. docker api 開發的端口怎么獲取?
排行榜
