Add health checks to your Laravel applications with this package.
First, use Composer to install this package.
$ composer require phpsafari/health-checksAfter the package has been installed, go ahead and add ``PhpSafari\ServiceProvider\HealthCheckServiceProvider::classto yourconfig/app.php` file.
After doing this, you can publish the health.php configuration file into your config folder by running:
$ php artisan vendor:publish --tag=healthInside the config/health.php file is where you configure all your available health checks. By default, this package comes packed with a few checks already:
CorrectEnvironmentwill check if your application's environment is set toproductionDatabaseOnlinewill check your database connectionDatabaseUpToDatewill check if your application has any migrations that hasn't been migrated yetDebugModeOffwill check if debug mode is offQueueProcessingwill check if the queue is running and jobs are getting processedPathIsWritablewill check if a provided path is writableLogLevelwill check if log level is set to the given valueMaxRatioOf500Responseswill check if the ratio of 500 response are above a given threshold (The last 60 min)MaxResponseTimeAvgwill check if average response time for all request are above a given threshold (The last 60 min)
To run a health check of your application, run:
$ php artisan health:checkYou can also use Laravel's scheduler to schedule your health checks:
$schedule->command('health:check')->hourly();You can also run a health check by hitting the https://<APP_URL>/_health url in a browser or with a tool like Pingdom.
Note: _This feature can be disabled in the config/health.php file, by setting route.enabled to false.
You can navigate to https://<APP_URL>/_health/stats and get all stats, including avg response time,
In order to create your own health checks, you just need to extend the PhpSafari\Checks\HealthCheck class and implement the run() method.
Example:
class IsFriday extends PhpSafari\Checks\HealthCheck
{
public function run(): bool
{
return Carbon::now()->isFriday();
}
}Then add new IsFriday() to the list of checks in config/health.php.
$ phpunit tests/If you discover any security related issues, please email :author_email instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.



