speakol-ads / elastic-apm-laravel
A package to integrate Elastic APM into Laravel
Requires
- php: >= 7.0
- illuminate/database: 5.5.x|5.6.x|5.7.x|5.8.x
- illuminate/http: 5.5.x|5.6.x|5.7.x|5.8.x
- illuminate/routing: 5.5.x|5.6.x|5.7.x|5.8.x
- illuminate/support: 5.5.x|5.6.x|5.7.x|5.8.x
- ramsey/uuid: ^3.0
- speakol-ads/elastic-apm-php-agent: >=7.1
Requires (Dev)
- phpunit/phpunit: 6.*
This package is auto-updated.
Last update: 2024-12-10 18:19:28 UTC
README
Laravel package of the https://github.com/speakol-ads/elastic-apm-php-agent library, automatically handling transactions and errors/exceptions. If using Illuminate\Support\Facades\Auth
the user Id added to the context.
Tested with Laravel 5.8.*
and the philkra/elastic-apm-php-agent version 7.*
.
Install
composer require speakol-ads/elastic-apm-laravel
Middleware
Laravel
Register as (e.g.) global middleware to be called with every request. https://laravel.com/docs/5.8/middleware#global-middleware
Register the middleware in app/Http/Kernel.php
protected $middleware = [ // ... more middleware \PhilKra\ElasticApmLaravel\Middleware\RecordTransaction::class, ];
Lumen
In bootstrap/app.php
register PhilKra\ElasticApmLaravel\Middleware\RecordTransaction::class
as middleware:
$app->middleware([ PhilKra\ElasticApmLaravel\Middleware\RecordTransaction::class ]);
Spans
Laravel
A Transaction object is made available via the dependency container and can be used to start a new span at any point in the application. The Span will automatically add itself to the Transaction when it is ended.
// Use any normal Laravel method of resolving the dependency $transaction = app(\PhilKra\ElasticApmLaravel\Apm\Transaction::class); $span = $transaction->startNewSpan('My Span', 'app.component_name'); // do some stuff $span->end();
Lumen
pending
Error/Exception Handling
Laravel
In app/Exceptions/Handler
, add the following to the report
method:
\ElasticApm::captureThrowable($exception, [], request()->__apm__());
Lumen
not tested yet.
Agent Configuration
Laravel
The following environment variables are supported in the default configuration:
You may also publish the elastic-apm.php
configuration file to change additional settings:
php artisan vendor:publish --tag=config
Once published, open the config/elastic-apm.php
file and review the various settings.
Laravel Test Setup
Laravel provides classes to support running unit and feature tests with PHPUnit. In most cases, you will want to explicitly disable APM during testing since it is enabled by default. Refer to the Laravel documentation for more information (https://laravel.com/docs/5.8/testing).
Because the APM agent checks it's active status using a strict boolean type, you must ensure your APM_ACTIVE
value is a boolean false
rather than simply a falsy value. The best way to accomplish this is to create an .env.testing
file and include APM_ACTIVE=false
, along with any other environment settings required for your tests. This file should be safe to include in your SCM.