stryber / laravel-metrics
Stryber Laravel metrics collector
Installs: 25
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 7
Forks: 0
Open Issues: 0
pkg:composer/stryber/laravel-metrics
Requires
- php: >=8.0
- illuminate/console: ^8.32
- illuminate/contracts: ^8.0
- illuminate/database: ^8.0
- illuminate/http: ^8.33
- illuminate/support: ^8.0
- influxdata/influxdb-client-php: ^1.10
- ramsey/uuid: ^4.1
- stryber/laravel-uuid-helper: ^8.0
Requires (Dev)
- roave/security-advisories: dev-master
- vimeo/psalm: ^4.6
This package is auto-updated.
Last update: 2024-04-29 04:21:35 UTC
README
Stryber Metrics Collector for Laravel
Table of Contents
Requirements
- PHP ^8.0
- Laravel ^8.0
- InfluxDB >= 2.0
Installation
composer require stryber/laravel-metrics
Configuration
You can publish the config files with the following command:
php artisan vendor:publish --tag="stryber-mectrics"
Check examples folder for:
- env.example env file with variables you should use to configure the package - copy them to your .env
- docker-compose.yml docker-compose file with influxdb service example
- main_dashboard.json exported influxdb dashboard to import on new influxdb instance
Usage
For now package supports 1 driver - influxdb and collects 3 metrics - Command, Request and Query.
Command and Query metrics will be collected automatically after you install the package.
To make Request metrics work you have to enable middleware called 'collect-metrics'.
Feel free to add your own metric classes to collect metrics in your project.
For this you should extend \Stryber\Metrics\Collectables\Metric class and, if you're using influxdb, make
transformer from \Stryber\Metrics\Drivers\Influx\Transformers\MetricTransformer or
\Stryber\Metrics\Drivers\Influx\Transformers\Transformer based on your needs.
If so, don't forget to add your transformer's resolver to config.
Known Issues
If you want to fill metric's storage with some data don't use laravel test setup.
Based of current state of stryber/laravel-uuid-helper and laravel test request realization you will have all
metrics with the same request-id.