Health Checks
The application uses spatie/laravel-health for monitoring system health. Health checks run every minute through the scheduler and monitor critical application services.
Registered Health Checks
Section titled “Registered Health Checks”The following health checks are registered by default in HealthServiceProvider:
| Check | Description | Environment |
|---|---|---|
| Database | Verifies database connectivity | Production only |
| Queue | Verifies queue system is operational | All |
| Cache | Verifies cache system is operational | All |
| Schedule | Verifies scheduled tasks have run recently | All |
| Debug Mode | Ensures debug mode is disabled | Non-local |
| Optimized App | Ensures app is optimized | Non-local |
| Security Advisories | Checks for known package vulnerabilities | All |
| Directory Search | Verifies Northwestern Directory Search API | All |
Additional checks are available for services like Redis, Horizon, Octane, and more. See the available checks documentation for a complete list. To add a check, register it in the HealthServiceProvider.
API Endpoint
Section titled “API Endpoint”A public health check endpoint is available for external monitoring systems.
Endpoint: GET /api/health
Authentication: None
Response:
{ "finishedAt": 1703299200, "checkResults": [ { "name": "database", "label": "Database", "notificationMessage": "Database is operational", "shortSummary": "OK", "status": "ok", "meta": {} } ]}HTTP Status Codes:
| Code | Meaning |
|---|---|
200 | All health checks passing |
503 | One or more health checks failing |
Check Status Values:
| Status | Description |
|---|---|
ok | Check passed |
warning | Check passed with warnings |
failed | Check failed |
crashed | Check threw an exception |
skipped | Check was conditionally skipped |
Notifications
Section titled “Notifications”Health checks run every minute through the scheduler, but email notifications are disabled by default. To receive alerts when checks fail, enable notifications and configure a recipient email address.
Enabling Notifications
Section titled “Enabling Notifications”Add the following to your .env file:
HEALTH_NOTIFICATIONS_ENABLED=trueHEALTH_NOTIFICATION_EMAIL=your-team@northwestern.eduResult Storage
Section titled “Result Storage”The application uses EloquentHealthResultStore to persist health check results in the database. This enables:
- Viewing health status in the admin panel’s Platform Overview page
- Historical tracking for trend analysis
- Results available immediately after scheduler runs
Results are automatically pruned after 5 days to prevent unbounded database growth.
Adding Custom Health Checks
Section titled “Adding Custom Health Checks”Creating a Check
Section titled “Creating a Check”Create a new check class extending Spatie\Health\Checks\Check:
<?php
namespace App\Domains\Core\Health;
use Spatie\Health\Checks\Check;use Spatie\Health\Checks\Result;
class CustomServiceCheck extends Check{ protected ?string $label = 'Custom Service';
public function run(): Result { $result = Result::make();
try { $isHealthy = $this->checkService();
if ($isHealthy) { return $result ->ok() ->shortSummary('Service operational'); }
return $result ->failed('Service unavailable') ->shortSummary('Service down'); } catch (\Exception $e) { return $result ->failed($e->getMessage()) ->shortSummary('Check failed'); } }
private function checkService(): bool { // Your health check logic here return true; }}Registering the Check
Section titled “Registering the Check”Add your check to HealthServiceProvider:
Health::checks([ // ... existing checks CustomServiceCheck::new(),]);Conditional Checks
Section titled “Conditional Checks”Run checks only in specific environments:
CustomServiceCheck::new() ->if(App::isProduction()),Or skip checks in certain environments:
CustomServiceCheck::new() ->unless(App::isLocal()),