jildertmiedema / laravel-system-monitor
Laravel system monitor, export application info to statsd
Installs: 52 667
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/jildertmiedema/laravel-system-monitor
Requires
- php: ^7.1.3
- illuminate/config: 5.6.*
- illuminate/console: 5.6.*
- illuminate/container: 5.6.*
- illuminate/database: 5.6.*
- illuminate/redis: 5.6.*
- illuminate/support: 5.6.*
- league/statsd: ^1.4
Requires (Dev)
- phpunit/phpunit: ^5.7
- squizlabs/php_codesniffer: ^2.3
README
This package will be monitor application metrices. It is dynamic configurable, but with the default settings you will be able to show some basic stuff.
This package usage statsd as a default output but off course you can implement your own store
Install
This package depends on the statsd client from the php league. Read their manual to get it up and running
Install the package:
composer require jildertmiedema/laravel-system-monitor
Add these lines in the config/app.php file in the providers array.
JildertMiedema\SystemMonitor\SystemMonitorServiceProvider::class, League\StatsD\Laravel5\Provider\StatsdServiceProvider::class,
If you've added the artisan schedule:run command to your cron, then you can add this to your App\Console\Kernel class
protected function schedule(Schedule $schedule) { $schedule->command('measurement:run')->everyMinute(); }
Now the system will send the measurement results to Statsd every minute
Configuration
To publish the config use:
php artisan vendor:publish --tag="config"
Change the config/measurement.php file to your needs.
Measurements can be configured by choosing a type and key.
The type is the type of the type of the measurement.
The key is the statsd key.
Per type some additional settings are required.
mysql.speedThe reaction time of a mysql connection. (Configure aconnection)redis.speedThe reaction time of a redis connection. (Configure aconnection)queue.sizeMeasures to amount of items in the queue. (Configure aqueue)queue.waiting-timePut a job on the queue and measures how long it takes before its handled by the queue. (Configure aqueue)
Testing
Run this command to show the result as console output.
php artisan measurement:run --debug
Statsd server
This package is design to be send to a statsd server.
Of course you can implement your own MeasurementStore to send it elsewhere.
Some docker stuff is created to receive (and show) data. Show me
Extending
This package comes with a default setup, but you can easly extend or replace parts.
To create your own measurement, create a new class that implements the JildertMiedema\SystemMonitor\Measurements\Measurement interface.
To register your class insert this in a service provider:
use JildertMiedema\SystemMonitor\Measurements\Manager; $this->app->resolving('measurement', function (Manager $manager) { $manager->extend($this->app[YourMeasurementClass::class]); });