0to10 / observability-php
Library to simplify customising observability integrations in PHP projects.
Requires
- php: >=7.3 | >8.0
- guzzlehttp/guzzle: ^6.2 | ^7.0.0
- monolog/monolog: ~2.3.5
- psr/log: ^1.1.4
Requires (Dev)
- johnkary/phpunit-speedtrap: ^4.0.1
- phpunit/phpunit: ^9.5.11
Suggests
- ext-newrelic: >=9.0
- newrelic/monolog-enricher: >=2.0.0
Replaces
- nouve/application-monitoring: ^1.2.3
This package is auto-updated.
Last update: 2024-11-13 20:29:08 UTC
README
Observability library for PHP
This package aims to make it easier to monitor your application by generalising frequently used methods to customise how you instrument your code.
Getting started
Getting started is usually easy: just follow the instructions below.
Installation
Use Composer to install this library into your project:
composer require 0to10/observability-php
Basic usage
Below is the high-level documentation of how to work with this library.
<?php require 'vendor/autoload.php'; use ZERO2TEN\Observability\Client; use ZERO2TEN\Observability\APM\Agent\NullAgent; $nullAgent = new NullAgent(); $client = new Client($nullAgent); try { // Some application code } catch (\Exception $e) { $client->transaction()->recordException($e); } // Add a parameter to the current transaction $client->transaction()->addParameter('user_id', 50);
Working with transactions
A Transaction is a logical unit of work in a software application. This might be handling a request and sending a response (in a Web transaction), executing a script that handles some piece of business logic, etc.
This library exposes a helper class via the transaction()
method of a
Client
instance that can be used to customise monitoring of a transaction.
The methods of the returned class are documented in TransactionInterface
.
Real-user monitoring
Real-user monitoring (RUM) may be customised by calling the browser()
method
of a Client
instance.
Automatic instrumentation (e.g. automatic injection of browser scripts in the header and footer of a page) may be disabled using the following method:
<?php require 'vendor/autoload.php'; use ZERO2TEN\Observability\Client; use ZERO2TEN\Observability\APM\Agent\NullAgent; $client = new Client(new NullAgent); $browser = $client->browser(); $browser->disableAutomaticTimingScripts();
Note that this must be done before any output is sent to the browser, and that it's more stable to disable RUM as part of your PHP configuration (if available).
<?php require 'vendor/autoload.php'; use ZERO2TEN\Observability\Client; use ZERO2TEN\Observability\APM\Agent\NullAgent; $client = new Client(new NullAgent); $browser = $client->browser(); // Returns the header RUM script (Javascript) as string without <script> tags $browser->getHeaderScript(); // Returns the footer RUM script (Javascript) as string without <script> tags $browser->getFooterScript();
Legacy usage
Library versions up to 2.0.0 continue to support using the Client
class located
in the Nouve\APM
namespace. Please do not use this method for new projects.
<?php require 'vendor/autoload.php'; use Nouve\APM\Agents\NullAgent; use Nouve\APM\Client; // Creates a Client instance with the first supported AgentInterface // implementation configured in the Client class $client = Client::create(); // Alternatively, you can instantiate a Client instance yourself $nullAgent = new NullAgent(); $client = new Client($nullAgent);
Usage notes
It is important to understand that this library exposes generic methods to adjust observability within projects. Depending on the capabilities of the used observability tool, methods may not have the desired outcome. Always make sure that you understand the impact of customising your setup before publishing this into any production environment.