Download the PHP package ralphjsmit/laravel-horizon-cron-supervisor without Composer
On this page you can find all versions of the php package ralphjsmit/laravel-horizon-cron-supervisor. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ralphjsmit/laravel-horizon-cron-supervisor
More information about ralphjsmit/laravel-horizon-cron-supervisor
Files in ralphjsmit/laravel-horizon-cron-supervisor
Package laravel-horizon-cron-supervisor
Short Description A modern solution for running Laravel Horizon with a CRON-based supervisor.
License MIT
Informations about the package laravel-horizon-cron-supervisor
A modern solution for running Laravel Horizon with a cron-based supervisor
Run Laravel Horizon on cheap hosting environments without Supervisor🤑
This Laravel package automatically checks every three minutes if your Laravel Horizon instance is still running. In that way, it is the perfect replacement for the normally recommended Supervisor Process Control System, for which you need your own server.
This package allows running Laravel Horizon on shared hosting instances and servers where you don't have to option to install Supervisor.
Under the hood, the package automatically schedules a simple Artisan command to run every three minutes that checks whether Horizon is still running. If not, it'll restart the Horizon queues.
Installation
Run the following command to install the package:
The package works without any configuration. Note that you need to have the Laravel Scheduler configured correctly.
Publishing the config file
You can publish the config file or just use the environment variables.
The config file contents.
How does this work with new deployments?
When you deploy a new version of your app, you usually shut down your queues and Horizon instances in order let them use the files. The Laravel Scheduler doesn't run any commands when your application is in maintenance mode (php artisan down
). Thus as long as your application is in maintenance mode, you don't need to worry about this package restarting your queues when you don't want that.
A typical deployment workflow could look something like this:
Note that this workflow is greatly simplified and doesn't take into account anything specific to your server or running commands like your migrations.
About the package
This package was created by Ralph J. Smit. Checkout my website ralphjsmit.com for Laravel and development-related tutorials.
The package was inspired by this StackOverflow question and my need for this as well. Special thanks to ahoffman for his code on running and checking whether Horizon is active.