php自我诊断检查表,在Laravel应用程序上执行自我诊断测试

Perform Self-Diagnosis Tests On Your Laravel Application

68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f6265796f6e64636f64652f6c61726176656c2d73656c662d646961676e6f7369732e7376673f7374796c653d666c61742d73717561726568747470733a2f2f696d672e736869656c64732e696f2f7472617669732f6265796f6e64636f64652f6c61726176656c2d73656c662d646961676e6f7369732f6d61737465722e7376673f7374796c653d666c61742d73717561726568747470733a2f2f696d672e736869656c64732e696f2f7363727574696e697a65722f672f6265796f6e64636f64652f6c61726176656c2d73656c662d646961676e6f7369732e7376673f7374796c653d666c61742d73717561726568747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f6265796f6e64636f64652f6c61726176656c2d73656c662d646961676e6f7369732e7376673f7374796c653d666c61742d737175617265

This package allows you to run self-diagnosis tests on your Laravel application. It comes with multiple checks out of the box and allows you to add custom checks yourself.

Here is an example output of the command:

a5ce9b5b9fdc939a0bd6f60f760554b8.png

Included checks

Is the APP_KEY set?

Are your composer dependencies up to date with the composer.lock file?

Do you have the correct PHP version installed?

Do you have the correct PHP extensions installed?

Can a connection to the database be established?

Do the storage and bootstrap/cache directories have the correct permissions?

Does the .env file exist?

Is the maintenance mode disabled?

Are the required locales installed on the system?

Are there environment variables that exist in .env.example but not in .env?

Are there any migrations that need to be run?

Is the storage directory linked?

Can Redis be accessed?

Development environment checks

Is the configuration not cached?

Are the routes not cached?

Are there environment variables that exist in .env but not in .env.example?

Production environment checks

Is the configuration cached?

Are the routes cached?

Is the xdebug PHP extension disabled?

Is APP_DEBUG set to false?

Are certain servers reachable?

Are certain supervisor programs running?

Installation

You can install the package via composer:

composer require beyondcode/laravel-self-diagnosis

If you're using Laravel 5.5+ the SelfDiagnosisServiceProvider will be automatically registered for you.

Usage

Just call the artisan command to start the checks:

php artisan self-diagnosis

Customization

You can publish the configuration file, that contains all available checks using:

php artisan vendor:publish --provider=BeyondCode\\SelfDiagnosis\\SelfDiagnosisServiceProvider

This will publish a self-diagnosis.php file in your config folder. This file contains all the checks that will be performed on your application.

return [

/*

* A list of environment aliases mapped to the actual environment configuration.

*/

'environment_aliases' => [

'prod' => 'production',

'live' => 'production',

'local' => 'development',

],

/*

* Common checks that will be performed on all environments.

*/

'checks' => [

\BeyondCode\SelfDiagnosis\Checks\AppKeyIsSet::class,

\BeyondCode\SelfDiagnosis\Checks\CorrectPhpVersionIsInstalled::class,

\BeyondCode\SelfDiagnosis\Checks\DatabaseCanBeAccessed::class => [

'default_connection' => true,

'connections' => [],

],

\BeyondCode\SelfDiagnosis\Checks\DirectoriesHaveCorrectPermissions::class => [

'directories' => [

storage_path(),

base_path('bootstrap/cache'),

],

],

\BeyondCode\SelfDiagnosis\Checks\EnvFileExists::class,

\BeyondCode\SelfDiagnosis\Checks\ExampleEnvironmentVariablesAreSet::class,

\BeyondCode\SelfDiagnosis\Checks\LocalesAreInstalled::class => [

'required_locales' => [

'en_US',

'en_US.utf8',

],

],

\BeyondCode\SelfDiagnosis\Checks\MaintenanceModeNotEnabled::class,

\BeyondCode\SelfDiagnosis\Checks\MigrationsAreUpToDate::class,

\BeyondCode\SelfDiagnosis\Checks\PhpExtensionsAreInstalled::class => [

'extensions' => [

'openssl',

'PDO',

'mbstring',

'tokenizer',

'xml',

'ctype',

'json',

],

'include_composer_extensions' => true,

],

\BeyondCode\SelfDiagnosis\Checks\StorageDirectoryIsLinked::class,

],

/*

* Environment specific checks that will only be performed for the corresponding environment.

*/

'environment_checks' => [

'development' => [

\BeyondCode\SelfDiagnosis\Checks\ComposerWithDevDependenciesIsUpToDate::class => [

'additional_options' => '--ignore-platform-reqs',

],

\BeyondCode\SelfDiagnosis\Checks\ConfigurationIsNotCached::class,

\BeyondCode\SelfDiagnosis\Checks\RoutesAreNotCached::class,

],

'production' => [

\BeyondCode\SelfDiagnosis\Checks\ComposerWithoutDevDependenciesIsUpToDate::class => [

'additional_options' => '--ignore-platform-reqs',

],

\BeyondCode\SelfDiagnosis\Checks\ConfigurationIsCached::class,

\BeyondCode\SelfDiagnosis\Checks\DebugModeIsNotEnabled::class,

\BeyondCode\SelfDiagnosis\Checks\PhpExtensionsAreDisabled::class => [

'extensions' => [

'xdebug',

],

],

\BeyondCode\SelfDiagnosis\Checks\RedisCanBeAccessed::class => [

'default_connection' => true,

'connections' => [],

],

\BeyondCode\SelfDiagnosis\Checks\RoutesAreCached::class,

\BeyondCode\SelfDiagnosis\Checks\ServersArePingable::class => [

'servers' => [

'www.google.com',

['host' => 'www.google.com', 'port' => 8080],

'8.8.8.8',

['host' => '8.8.8.8', 'port' => 8080, 'timeout' => 5],

],

],

\BeyondCode\SelfDiagnosis\Checks\SupervisorProgramsAreRunning::class => [

'programs' => [

'horizon',

],

'restarted_within' => 300, // max seconds since last restart, 0 to disable check

],

],

],

];

Available Configuration Options

The following options are available for the individual checks:

BeyondCode\SelfDiagnosis\Checks\ComposerWithDevDependenciesIsUpToDate

additional_options (string, optional parameters like '--ignore-platform-reqs'): optional arguments for composer

BeyondCode\SelfDiagnosis\Checks\ComposerWithoutDevDependenciesIsUpToDate

additional_options (string, optional parameters like '--ignore-platform-reqs'): optional arguments for composer

BeyondCode\SelfDiagnosis\Checks\DatabaseCanBeAccessed

default_connection (boolean, default: true): if the default connection should be checked

connections (array, list of connection names like ['mysql', 'sqlsrv'], default: []): additional connections to check

BeyondCode\SelfDiagnosis\Checks\DirectoriesHaveCorrectPermissions

directories (array, list of directory paths like [storage_path(), base_path('bootstrap/cache')], default: []): directories to check

BeyondCode\SelfDiagnosis\Checks\LocalesAreInstalled

required_locales (array, list of locales like ['en_US', 'en_US.utf8'], default: []): locales to check

BeyondCode\SelfDiagnosis\Checks\PhpExtensionsAreDisabled

extensions (array, list of extension names like ['xdebug', 'zlib'], default: []): extensions to check

BeyondCode\SelfDiagnosis\Checks\PhpExtensionsAreInstalled

extensions (array, list of extension names like ['openssl', 'PDO'], default: []): extensions to check

include_composer_extensions (boolean, default: false): if required extensions defined in composer.json should be checked

BeyondCode\SelfDiagnosis\Checks\RedisCanBeAccessed

default_connection (boolean, default: true): if the default connection should be checked

connections (array, list of connection names like ['cache_1', 'cache_2'], default: []): additional connections to check

BeyondCode\SelfDiagnosis\Checks\SupervisorProgramsAreRunning

programs (array, list of programs like ['horizon', 'another-program'], default: []): programs that are required to be running

restarted_within (integer, max allowed seconds since last restart of programs (0 = disabled), default: 0): verifies that programs have been restarted recently to grab code updates

BeyondCode\SelfDiagnosis\Checks\ServersArePingable

servers (array, list of servers and parameters like ['google.com', ['host' => 'google.com', 'port' => 8080]]): servers to ping

Custom Checks

You can create custom checks, by implementing the BeyondCode\SelfDiagnosis\Checks\Check interface and adding the class to the config file. Like this:

use BeyondCode\SelfDiagnosis\Checks\Check;

class MyCustomCheck implements Check

{

/**

* The name of the check.

*

* @param array $config

* @return string

*/

public function name(array $config): string

{

return 'My custom check.';

}

/**

* Perform the actual verification of this check.

*

* @param array $config

* @return bool

*/

public function check(array $config): bool

{

return true;

}

/**

* The error message to display in case the check does not pass.

*

* @param array $config

* @return string

*/

public function message(array $config): string

{

return 'This is the error message that users see if "check" returns false.';

}

}

Example Output

df2e357a32d4f3f22915c1a7c3697dbb.png

Testing

composer test

Changelog

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email marcel@beyondco.de instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值