首頁技術(shù)文章正文

寫爬蟲是用多進程還是多線程?

更新時間:2021-05-21 來源:黑馬程序員 瀏覽量:

1577370495235_學(xué)IT就到黑馬程序員.gif

一般情況下,在選擇是使用多進程還是多線程時,主要考慮的業(yè)務(wù)到底是IO密集型(多線程)還是計算密集型(多進程)。在爬蟲中,請求的并發(fā)業(yè)務(wù)屬于是網(wǎng)絡(luò)的IO類型業(yè)務(wù),因此網(wǎng)絡(luò)并發(fā)適宜使用多線程;但特殊需求下,比如使用phantomjs 或者chrome-headless來抓取的爬蟲,應(yīng)當是多進程的,因為每一個phan/chro實例就是一個進程了,并發(fā)只能是多進程。此外爬蟲中還是數(shù)據(jù)處理業(yè)務(wù),如果數(shù)據(jù)處理業(yè)務(wù)是一個比較耗時的計算型操作,那么對數(shù)據(jù)處理部分應(yīng)當設(shè)為多進程,但更多可能會考慮將該部分數(shù)據(jù)處理操作和爬蟲程序解耦,也就是先把數(shù)據(jù)抓取下來,事后單獨運行另外的程序解析數(shù)據(jù)。


以下是黑馬程序員近期推出的Python興趣課程,3天入門Python,體驗Python的魅力!

0基礎(chǔ)Python3天入門課程

   ·了解Python主流就業(yè)方向,把握最新熱點技術(shù)
   ·掌握Python的基礎(chǔ)語法及API調(diào)用
   ·能夠使用Python對數(shù)據(jù)獲取、使用和展示
   ·打造自己的數(shù)據(jù)分析項目并自動生成工作報告

Python零基礎(chǔ)3天課程


分享到:
在線咨詢 我要報名
和我們在線交談!