1. Go to this page and download the library: Download fullpipe/check-them library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
fullpipe / check-them example snippets
use Fullpipe\CheckThem\Checks\PDOCheck;
$mysqlCheck = new PDOCheck('mysql:dbname=test_db;host=127.0.0.1:3306', 'username', 'password');
$status = $mysqlCheck->getStatus();
if(!$status->isUp()) {
$this->logger->warn('Mysql server is down', $status->getError());
exit;
}
use Fullpipe\CheckThem\Checks\AllInOneCheck;
use Fullpipe\CheckThem\Checks\PDOCheck;
use Fullpipe\CheckThem\Checks\HttpCheck;
use Fullpipe\CheckThem\Checks\RedisChecker;
...
$allInOne = new AllInOneCheck();
$allInOne->add(new PDOCheck('mysql:dbname=test_db;host=127.0.0.1:3306', 'username', 'password'));
$allInOne->add(new HttpCheck('user_service:8080'));
$allInOne->add(new RedisChecker('redis:6379'));
$status = $allInOne->getStatus();
if(!$status->isUp()) {
$this->logger->warn('Something is down', $status->getError());
exit;
}
// everything is fine
use Fullpipe\CheckThem\Checks\PDOCheck;
...
$mysqlCheck = new PDOCheck('mysql:dbname=test_db;host=127.0.0.1:3306', 'username', 'password');
$pgCheck = new PDOCheck('pgsql:host=localhost;port=8002;dbname=test_db', 'username', 'password');
use Fullpipe\CheckThem\Checks\HttpCheck;
...
$userCheck = new HttpCheck('http://user_service:8080/healthz');
$webCheck = new HttpCheck('https://google.com/');
$check = (new HttpCheck('http://user_service:8080/healthz'))
->setConnectionTimeout(3) // change connection timeout, default 1 second
;
use Fullpipe\CheckThem\Checks\RedisCheck;
...
$check = new RedisCheck('tcp://10.0.0.1:6379');
$check = new RedisCheck('unix:/path/to/redis.sock');
$check = (new RedisCheck('redis:6379'))
->setAuth('test_pass') // use password if ->setStreamTimeout(3) // timeout for socket read/write operations, default 1 second
;
use Fullpipe\CheckThem\Checks\PredisCheck;
...
$client = new Predis\Client([
'scheme' => 'tcp',
'host' => '10.0.0.1',
'port' => 6379,
]);
$check = new PredisCheck($client);
use Fullpipe\CheckThem\Checks\SocketCheck;
...
// you could use this check for mysql,
// it work fine and you don't need a password
$check = new SocketCheck('mysql:3306');
$check = (new SocketCheck('mysql:3306'))
->setConnectionTimeout(4) // timeout for server connection, default 1 second
->setStreamTimeout(3) // timeout for socket read/write operations, default 1 second
;
use Fullpipe\CheckThem\Checks\SocketConnectionCheck;
...
$check = new SocketConnectionCheck('rabbitmq:5672');
$check = (new SocketConnectionCheck('mysql:3306'))
->setConnectionTimeout(4) // timeout for server connection, default 1 second
;
use Fullpipe\CheckThem\Checks\AllInOneCheck;
use Fullpipe\CheckThem\Checks\SocketCheck;
use Fullpipe\CheckThem\Checks\RedisCheck;
...
$check = (new AllInOneCheck())
->add(new SocketCheck('mysql:3306'))
->add((new RedisCheck('tcp://10.0.0.1:6379'))->setAuth('redisPass'))
;
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.