jildertmiedema / laravel-system-monitor
Laravel system monitor, export application info to statsd
Installs: 51 429
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 1
Open Issues: 0
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.speed
The reaction time of a mysql connection. (Configure aconnection
)redis.speed
The reaction time of a redis connection. (Configure aconnection
)queue.size
Measures to amount of items in the queue. (Configure aqueue
)queue.waiting-time
Put 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]); });