在Python Celery中,如何在连续的工作调用中持久保存对象?
发布时间:2021-02-20 15:12:00 所属栏目:Python 来源:互联网
导读:我正在使用Celery来自动化一些屏幕抓取.我正在使用Selenium打开Chrome webdriver,操作页面,保存一些数据,然后转到队列中的下一页.问题在于它为队列中的每个任务构建和分解Web驱动程序,这非常耗时且占用大量资源. 如何在通话中保留对象?我已经阅读了有关Celer
我正在使用Celery来自动化一些屏幕抓取.我正在使用Selenium打开Chrome webdriver,操作页面,保存一些数据,然后转到队列中的下一页.问题在于它为队列中的每个任务构建和分解Web驱动程序,这非常耗时且占用大量资源. 如何在通话中保留对象?我已经阅读了有关Celery中连接池的一些内容,但我不清楚这是如何工作的 – 我在哪里构建webdriver – 在任务文件或主排队文件中?如果是后者,工人们如何知道使用哪个webdriver? 例: scrape.py: for page in list: scrape.delay(str(row['product_id']),str(row['pg_code'])) tasks.py: def scrape: # do some stuff 解决方法由于每个worker将任务实例化为单例,因此您可以将Web驱动程序缓存在任务对象中.文档特别提出了这种方法.http://docs.celeryproject.org/en/latest/userguide/tasks.html#instantiation (编辑:十堰站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- python中__call__内置函数用法实例
- python – Django:有没有办法在与包含ManyToManyField的模
- python – 逐行文件处理,for-loop vs with
- python – 可扩展程序的良好设计模式
- python – 从Azure ML中的pyodbc连接到Azure SQL数据库的驱
- python – Aiohttp,Asyncio:RuntimeError:事件循环已关闭
- python – matplotlib.pyplot.imshow:在使用属性“sharex”
- python – 在keras的LSTM中使用隐藏状态而不是输出
- python – 如何覆盖BaseHTTPRequestHandler log_message()方
- 使用Python / Sympy进行连续傅里叶变换(分析解决方案)
推荐文章
站长推荐
热点阅读