定制 letsgoi/laravel-health-check 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

letsgoi/laravel-health-check

最新稳定版本:4.0.0

Composer 安装命令:

composer require letsgoi/laravel-health-check

包简介

Laravel health checker

README 文档

README

Package to perform health check analysis based on defined checkers.

Requirements

  • PHP >= 8.3
  • Laravel >= 10.0

Instalation

  • Require package with composer:
composer require letsgoi/laravel-health-check
  • Publish configuration:
php artisan vendor:publish --provider="Letsgoi\HealthCheck\HealthCheckServiceProvider" --tag="config"

Service Provider will be automatically registered, however if you want to add it manually, you must add this to your config/app.php file:

'providers' => [
    // ...
    Letsgoi\HealthCheck\HealthCheckServiceProvider::class,
];

Configuration

You must set all checkers that want to pass your application at checkers array on config file (config/laravel_health_check.php):

'checkers' => [
    ...
    Letsgoi\HealthCheck\Checkers\DatabaseConnectionChecker::class,
    Letsgoi\HealthCheck\Checkers\WritablePathsChecker::class,
    ...
],

You can check any checker without check all, but this configuration is for general check.

Usage

Check individual checker

Use HealthCheck facade to check an individual checker:

use Letsgoi\HealthCheck\Facades;

HealthCheck::check(new Checker());

it will return true if check pass and it will throw HealthCheckerException if not.

Check all checkers defined at configuration file

To check all checkers defined at configuration file use healthCheck method of HealthCheck facade:

use Letsgoi\HealthCheck\Facades;

HealthCheck::healthCheck();

it will return true if all checks pass and throw HealthCheckerException with failed checkers if not.

Get check errors

If you want to get all check errors of checkers defined at configuration file, you can use getCheckErrors method:

use Letsgoi\HealthCheck\Facades;

HealthCheck::getCheckErrors();

It returns an array with all errors.

HealthCheck command

You can run the healthcheck with artisan command:

php artisan health-check

It show ok if all checks pass or exceptions if fails.

HealthCheck endpoint

You can configure an endpoint to check the health of your app. Configure it on config file (laravel_health_check):

...

'endpoint' => [
    'enabled' => env('HEALTH_CHECK_ENDPOINT_ENABLED', true), // Enable/disable endpoint

    'path' => env('HEALTH_CHECK_ENDPOINT_PATH', '/health-check'), // Configure path of endpoint

    'healthy_message' => env('HEALTH_CHECK_ENDPOINT_HEALTHY_MESSAGE', 'Healthy'), // Set ok message
],

...

It will return the ok message if all check passed or a server error with the array of errors.

Checkers

Available checkers

Those are the available predefined checkers:

  • Letsgoi\HealthCheck\Checkers\AppKeyChecker: Checks if there is an app key defined as environment variable.
  • Letsgoi\HealthCheck\Checkers\DatabaseConnectionChecker: Checks if the app can connect with default database connection.
  • Letsgoi\HealthCheck\Checkers\DatabaseMigrationsChecker: Checks if all migrations are up to date.
  • Letsgoi\HealthCheck\Checkers\DebugChecker: Checks if the app is not on debug mode.
  • Letsgoi\HealthCheck\Checkers\EnvFileChecker: Checks if there is an .env file.
  • Letsgoi\HealthCheck\Checkers\WritablePathsChecker: Checks if the necessary paths are writable.

Custom checkers

If you need some custom checker (or someone not available yet, PRs are welcome :)), you can do simply implementing the Letsgoi\HealthCheck\Contracts\HealthChecker contract.

It forces to implement a check method that returns true if check pass or false if not.

Then you can use normally adding to your config file or checking it with individual mode.

Testing

Run tests:

composer test

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

MIT

统计信息

  • 总下载量: 27.94k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 7
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 7
  • Watchers: 4
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-05-22