I have to run tasks on approximately 150k Django objects. What is the best way to do this? I am using the Django ORM as the Broker. The database backend is MySQL and chokes and dies during the task.delay() of all the tasks. Related, I was also wanting to kick this off from the submission of a form, but the resulting request produced a very long response time that timed out.
Share
I would also consider using something other than using the database as the “broker”. It really isn’t suitable for this kind of work.
Though, you can move some of this overhead out of the request/response cycle by launching a task to create the other tasks:
Also, since you probably don’t have 15000 processors to process all of these objects
in parallel, you could split the objects in chunks of say 100’s or 1000’s: