Laravel scheduler terminating your processes (sending SIGKILL signal)

Aug 09, 2024 / 1 min read

Language Mismatch Disclaimer: Please be aware that the language of this article may not match the language settings of your browser or device.
Do you want to read articles in English instead ?

It's likely that Supervisor is terminating processes that run longer than 10 seconds, which is the default value for stopwaitsecs.

Context

We have a scheduled command that runs every 5 minutes to:

  • Process data from two APIs
  • Combine the data (with additional processing)
  • Send it to a third API

This involves:

  • Approximately 20 HTTP requests per item
  • Around 1 second per request (for simplicity)
  • 4000 seconds to process all 200 items, but the scheduler kills any process running past 10 seconds due to the stopwaitsecs setting.

Solution

  • Increase stopwaitsecs: Set it to 200,000 to handle 1000 items in one command execution. The default is 10 seconds.
  • Increase numprocs: Set it to 2 instead of 1 for the scheduler, adjusting according to your server capacity.

For more information, refer to the Laravel documentation, which highlights this issue in detail. As always, the documentation is a great resource for troubleshooting.