2011-01-31 118 views
9

我正在使用Celery来处理多个数据挖掘任务。这些任务之一连接到远程服务,它允许最多10个同时连接每用户(或者换句话说,它CAN超过10个连接全球,但它CAN NOT超过每个人工作10个连接)。芹菜(Django)限速

认为Token Bucket (rate limiting)是我在找,但我似乎无法找到它的任何实施。

回答

3

经过一番研究,我发现,芹菜不明确提供了一种方法来限制像这样的并发实例的数量,而且这样做通常被认为是不好的做法。

更好的解决方案是在单个任务中同时下载,并使用Redis或Memcached来存储和分发其他任务进行处理。

3

虽然它可能是不好的做法,你可以使用一个专用的队列,并限制工人,如:

# ./manage.py celery worker -Q another_queue -c 10