Laravel package of the nipwaayoni/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.6.*
and the nipwaayoni/elastic-apm-php-agent version 7.1.*
.
This package is a continuation of the excellent work done by philkra at philkra/elastic-apm-laravel.
composer require nipwaayoni/elastic-apm-laravel
The nipwaayoni/elastic-apm-php-agent no longer includes and http client. You must ensure a PSR-18 compatible implementation is available. Please see the agent install guide for more information.
If using Laravel >=5.5, registration is done automatically by package discovery.
This package is not tested or asserted to work with Laravel <5.5.
In bootstrap/app.php
register \Nipwaayoni\ElasticApmLaravel\Providers\ElasticApmServiceProvider::class
as service provider:
$app->register(\Nipwaayoni\ElasticApmLaravel\Providers\ElasticApmServiceProvider::class);
Register as (e.g.) global middleware to be called with every request. https://laravel.com/docs/5.6/middleware#global-middleware
Register the middleware in app/Http/Kernel.php
protected $middleware = [
// ... more middleware
\Nipwaayoni\ElasticApmLaravel\Middleware\RecordTransaction::class,
];
The provided middleware adds request and response context data to the transaction. If the existing behavior does not suit your needs, you can provide your own middleware by overriding the class. See the documentation on customizing transactions for more information.
In bootstrap/app.php
register Nipwaayoni\ElasticApmLaravel\Middleware\RecordTransaction::class
as middleware:
$app->middleware([
Nipwaayoni\ElasticApmLaravel\Middleware\RecordTransaction::class
]);
The Elastic APM service supports a variety of event types. This package currently supports only a subset as described here.
The RecordTransaction
middleware automatically starts a new Transaction for the current HTTP Request.
All additional events will be descendents of this transaction.
There is currently no provision to manage additional Transaction events, or to handle a non-HTTP Request based process. We hope to address those issues in a future release.
While the RecordTransaction
middleware sets supported APM contexts when the transaction is created, you may wish to customize the contexts based on the completed request/response. This can be done by extending the RecordTransaction
middleware and overriding context methods as described in the customizing transactions documentation.
You can exclude requests from being sent to APM by using an except
list of URI patterns. For example, you may wish to avoid sending requests for the (DebugBar)[https://github.com/barryvdh/laravel-debugbar] resources during development or testing.
Add the desired URI patterns to the except
key in the elastic-apm
configuration. Note that you must publish the file as described in the configuration docs.
If you have extended the RecordTransaction
middleware, as described in the customizing transactions documentation, you may set the except
list class member there.
Spans occur within a Transaction. Spans represent events within the Transaction. Queries made through Laravel's
database layer are automatically added to the Transaction. You can add your own Span events using the EventTimer
class from this package. See the docs for creating spans.
Nested Spans are not supported by this package yet.
The APM service defines exception events as a valid type. Exceptions in your application can be sent to APM in addition to any normal exception handling. See the docs for exceptions.
You can use a number of environment settings to influence the behavior of this package. At a minimum, you must set the APM server URL and, if applicable, the secret toke:
Variable | Description |
---|---|
APM_SERVERURL | URL to the APM intake service. |
APM_SECRETTOKEN | Secret token, if required. |
Refer to the configuration docs for more information.
It is no longer possible to provide HTTP client options through the APM PHP Agent configuration. If you need to customize the HTTP client, you must implement and configure a suitable client object and provide it to the AgentBuilder
. See the "HTTP Client Configuration" section of the configuration docs.
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.7/testing).
Because the APM agent checks its 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.