I have a PHP application that currently has 5k users and will keep increasing for the forseeable future. Once a week I run a script that:
- fetches all the users from the database
- loops through the users, and performs some upkeep for each one (this includes adding new DB records)
The last time this script ran, it only processed 1400 users before dieing due to a 30 second maximum execute time error. One solution I thought of was to have the main script still fetch all the users, but instead of performing the upkeep process itself, it would make an asynchronous cURL call (1 for each user) to a new script that will perform the upkeep for that particular user.
My concern here is that 5k+ cURL calls could bring down the server. Is this something that could be remedied by using a messaging queue instead of cURL calls? I have no experience using one, but from what I’ve read it seems like this might help. If so, which message queuing system would you recommend?
Some background info:
- this is a Symfony project, using Doctrine as my ORM and MySQL as my DB
- the server is a Windows machine, and I’m using Windows’ task scheduler and wget to run this script automatically once per week.
Any advice and help is greatly appreciated.
If it’s possible, I would make a scheduled task (cron job) that would run more often and use
LIMIT 100(or some other number) to process a limited number of users at a time.