ilyaplot / pulse
A healthcheck framework for PHP
Requires
- php: ^8.1
Requires (Dev)
- phpunit/php-code-coverage: ^10.0
- phpunit/phpunit: ^10.0
- slevomat/coding-standard: ^8.8
- squizlabs/php_codesniffer: ^3.7
- vimeo/psalm: ^5.7
This package is auto-updated.
Last update: 2024-10-25 10:54:27 UTC
README
Pulse allows you to easily write healthchecks for your application and display a simple, aggregated report so you can quickly diagnose whether and why your app is having trouble (or whether you can blame someone else). You can also monitor your healthchecks with nagios, zabbix, etc.
Wait, what's a healthcheck?
Healthchecks are a great way to test system health and connectivity to other services. For example, you can verify connectivity to memcache or mysql, that your app can read / write to certain files, or that your API key for a third-party service is still working.
Installation
You can install this into your project using composer. Create a composer.json
file in the root of your project and add the following:
composer require ilyaplot/pulse
Include vendor/autoload.php
, and you're off to the races!
Warnings
For non-critical checks you can use a warning and you'll get status 200 even if these fail. Use these to see when your app is experiencing service degredation but is still available. Warning checks must return boolean true
or false
.
$pulse->addWarning(new ClosureRule( fn() => (new YoutubeClient())->isUp(), "Verify connectivity to youtube", LevelEnum::warning, ));
Information
$pulse->addInfo(new ClosureRule( fn() => (new YoutubeClient())->isUp(), "Verify connectivity to youtube", )); $pulse->addInfo(new ClosureRule( function(ClosureRule $closureRule) { $this->setErrorMessage( date('l')); return false; }, "Today is", )); $result = $pulse->run();
Custom Rules
You can also create your own custom rules by extending the ilyaplot\pulse\rules\AbstractRule
class or implementing ilyaplot\pulse\rules\RuleInterface
.
For example, you could create a rule that checks that your app can connect to a third-party service.
class YoutubeRule extends AbstractRule { public function __construct( private readonly string $apiKey, ) { $this->description = 'Verify connectivity to youtube'; $this->level = LevelEnum::warning; } public function run(): bool { $youtubeClient = new YoutubeClient($this->apiKey); try { return $youtubeClient->isUp(); // bool } catch (AuthenticationException) { $this->setErrorMessage('Invalid API key'); return false; } } }
Then you can add it to your healthcheck:
$pulse->add(new YoutubeRule('your-api-key-1')); $pulse->add(new YoutubeRule('your-api-key-2'));
Examples
You can see some very basic example healthchecks in examples/cli-usage.php
and examples/http-usage.php
.
$pulse = new ilyaplot\pulse\Pulse(); $pulse->add(new FileRule( '/path/to/your/config/file', description: "Check that config file is readable", checkIsReadable: true, )); include '/path/to/your/config/file'; $pulse->addCritical(new ClosureRule( function() use ($config) { $memcache = new Memcache(); if(!$memcache->connect($config['memcache_host'], $config['memcache_port'])){ return false; } $key = 'healthcheck_test_key' $msg = 'memcache is working'; $memcache->set($key, $msg); return $memcache->get($key) === $msg; }, "Check memcache connectivity" ));
Does Pulse Work With X?
Yep. Pulse is designed to be self-contained and is very simple, so it doesn't require you to use any particular framework. You are free to include other things like yml parsers, etc. if you choose, but we recommend NOT including a full framework stack on top of it. If the framework fails to load for some reason, your healthchecks won't be displayed, meaning they're not useful for diagnosing whatever problem you've encountered.
Won't This Expose Information About My App?
Potentially. You probably don't want to display the healthcheck results to the public. Instead, you could whitelist certain IPs.