簡體   English   中英

如何提高 aiohttp 爬蟲速度?

[英]How can I improve the aiohttp crawler speed?

import aiohttp
from bs4 import BeautifulSoup
from xlrd import open_workbook
from xlwt import Workbook

url_list = [https://www.facebook.com,https://www.baidu.com,https://www.yahoo.com,...]
#There are more than 20000 different websites in the list
#Some websites may not be accessible
keywords=['xxx','xxx'....]
start = time.time()
localtime = time.asctime(time.localtime(time.time()))
print("start time :", localtime)
choose_url=[]
url_title=[]
async def get(url, session):
    try:
        async with session.get(url=url,timeout=0) as response:
            resp = await response.text()
            soup = BeautifulSoup(resp, "lxml")
            title = soup.find("title").text.strip()
            for keyword in keywords:
                if keyword in title:
                    choose_url.append(url)
                    url_title.append(title)
                    print("Successfully got url {} with resp's name {}.".format(url, title))
                    break
    except Exception as e:
        pass

async def main(urls):
    connector = aiohttp.TCPConnector(ssl=False,limit=0,limit_per_host =0)
    session = aiohttp.ClientSession(connector=connector)
    ret = await asyncio.gather(*[get(url, session) for url in urls])
    print("Finalized all. Return is a list of outputs.")
    await session.close()
def write_exccel(choose_url,url_title):
    #write choose_url,url_title to excel 
    pass

asyncio.run(main(url_list))
write_exccel(choose_url,url_title)
localtime = time.asctime(time.localtime(time.time()))
print("now time is  :", localtime)
end = time.time()
print('time used:', end - start)

我有 20000 個 URL 請求。 但這需要很長時間(超過 4 或 5 小時)。如果我使用請求 + 多處理(池 4)只需要 3 小時。

我試過用aiohttp+multiprocessing,好像不行。 通過優化此代碼或使用任何可用技術,代碼能否盡可能快? 謝謝

不知道下面的方法快不快。

import time
from simplified_scrapy import Spider, SimplifiedDoc, SimplifiedMain, utils

class MySpider(Spider):
    name = 'demo_spider'
    start_urls = ["https://www.facebook.com","https://www.baidu.com","https://www.yahoo.com"]  # Entry page
    keywords = ['xxx','xxx']
    choose_url=[]
    url_title=[]
    concurrencyPer1s = 10
    def extract(self, url, html, models, modelNames):
        doc = SimplifiedDoc(html)
        title = doc.title
        if title.containsOr(self.keywords):
            self.choose_url.append(url.url)
            self.url_title.append(title.text)
            print("Successfully got url {} with resp's name {}.".format(url, title.text))
    def urlCount(self):
        count = Spider.urlCount(self)
        if count==0:
            SimplifiedMain.setRunFlag(False)
        return count

start = time.time()
localtime = time.asctime(time.localtime(time.time()))
print("start time :", localtime)
SimplifiedMain.startThread(MySpider(),{"concurrency":600, "concurrencyPer1S":100, "intervalTime":0.001, "max_workers":10})  # Start download
localtime = time.asctime(time.localtime(time.time()))
print("now time is  :", localtime)
end = time.time()
print('time used:', end - start)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM