vairogs / spx-profiler
A Symfony profiler data collector for the SPX PHP profiler, which collects and displays profiling data for PHP applications
Requires
- php: >=8.4
- symfony/dependency-injection: *
- symfony/framework-bundle: *
- symfony/http-foundation: *
- vairogs/bundle: dev-master
- vairogs/functions-iteration: dev-master
- vairogs/functions-text: dev-master
Suggests
- ext-spx: *
- symfony/twig-bundle: *
This package is auto-updated.
Last update: 2025-04-15 09:01:30 UTC
README
A Symfony profiler data collector for the SPX PHP profiler, which collects and displays profiling data for PHP applications.
Installation
Install the package via Composer:
composer require vairogs/spx-profiler
Requirements
- PHP 8.4 or higher
- SPX PHP extension installed
Usage
The SpxProfiler component provides a data collector for the Symfony web profiler that integrates with the SPX PHP profiler. It allows you to view detailed profiling information for your PHP applications directly in the Symfony web profiler.
Basic Setup
- Install the SPX PHP extension (https://github.com/NoiseByNorthwest/php-spx)
- Enable the extension in your php.ini:
extension=spx.so spx.http_enabled=1 spx.http_key=your_secret_key
- Register the component in your Symfony application:
// config/bundles.php return [ // ... Vairogs\Bundle\VairogsBundle::class => ['all' => true], // ... ];
- Configure the component in your Symfony application:
# config/packages/vairogs.yaml vairogs: components: spx_profiler: ~
Viewing Profiling Data
Once the component is installed and configured, you can view profiling data in the Symfony web profiler:
- Enable SPX profiling for a request by adding the SPX_KEY parameter to the URL or setting the SPX_ENABLED cookie to 1
- Make a request to your application
- Open the Symfony web profiler for that request
- Click on the SPX tab to view the profiling data
Features
The SpxProfiler component provides the following features:
- Integration with the Symfony web profiler
- Display of SPX profiling data in a dedicated tab
- Automatic matching of SPX reports with Symfony profiler requests
- Display of detailed metrics including:
- Wall time
- Memory usage
- Enabled metrics
- Recorded calls
- Links to the full SPX report for more detailed analysis
Configuration Options
The SPX PHP extension provides several configuration options that can be set in your php.ini:
spx.http_enabled
: Enable HTTP interface (default: 0)spx.http_key
: Secret key for HTTP interfacespx.http_ip_whitelist
: IP whitelist for HTTP interfacespx.data_dir
: Directory for SPX data files (default: /tmp/spx)
License
This package is licensed under the BSD-3-Clause License.
About Vairogs
This package is part of the vairogs/vairogs project - a comprehensive PHP library and Symfony bundle that provides a collection of utilities, components, and integrations for Symfony applications.
The main project includes:
- Various utility functions and components
- Doctrine ORM tools and extensions
- API Platform integrations
- Symfony bundle for easy configuration
- And much more
If you find this SpxProfiler component useful, you might want to check out the full Vairogs project for additional tools and utilities that can enhance your Symfony application development.
To install the complete package:
composer require vairogs/vairogs