Skip to main content
Glama
brianirish

Laravel 12 Docs MCP Server

by brianirish
collectors.md14.4 kB
# Debugbar - Collectors Source: https://laraveldebugbar.com/collectors/ Warning Debugbar can slow the application down (because it has to gather and render data). So when experiencing slowness, try disabling some of the collectors. Collectors¶ =========== This package includes with these Collectors enabled by default: * Queries: Show all database queries * Messages: Debug messages and objects * Logger: Show all Log messages (Show in Messages when available) * Views: Show the currently loaded views. * Timeline: Timeline with Booting and Application timing * Route: Show information about the current Route. * Exceptions: Exceptions and Throwable with stacktrace * Session: Current session data * Request: Request data * Livewire: Only active when Livewire is used * PhpInfo: Current PHP version These collectors can be enabled in the config: * Gate: Show the gates that are checked * Events: Show all events * Auth: Logged in status * Mail: Sent emails * Laravel Info: Show the Laravel version and Environment. * Memory: Memory usage * Config: Display the values from the config files. * Cache: Display all cache events. * Models: Loaded Models * Jobs: Sent emails * Logs: Logs from the log files * Pennant: Show Pennant flags * Files: Show the files that are included/required by PHP. To enable or disable any of the collectors, set the configuration to `true` or `false`. Some collector have additional options in the configuration: config/debugbar.php ```php /* |-------------------------------------------------------------------------- | DataCollectors |-------------------------------------------------------------------------- | | Enable/disable DataCollectors | */ 'collectors' => [ 'phpinfo' => true, // Php version 'messages' => true, // Messages 'time' => true, // Time Datalogger 'memory' => true, // Memory usage 'exceptions' => true, // Exception displayer 'log' => true, // Logs from Monolog (merged in messages if enabled) 'db' => true, // Show database (PDO) queries and bindings 'views' => true, // Views with their data 'route' => true, // Current route information 'auth' => false, // Display Laravel authentication status 'gate' => false, // Display Laravel Gate checks 'session' => true, // Display session data 'symfony_request' => true, // Only one can be enabled.. 'mail' => false, // Catch mail messages 'laravel' => false, // Laravel version and environment 'events' => false, // All events fired 'default_request' => false, // Regular or special Symfony request logger 'logs' => false, // Add the latest log messages 'files' => false, // Show the included files 'config' => false, // Display config settings 'cache' => false, // Display cache events 'models' => false, // Display models 'livewire' => true, // Display Livewire (when available) 'jobs' => false, // Display dispatched jobs 'pennant' => false, // Display Pennant feature flags ], ``` Database Queries¶ ----------------- v1.0 collectors.db The Query Collector has the following features - Show the executed queries including timing - Show/mark duplicate queries - Show used parameters - Run on-demand 'EXPLAIN' queries and link to Visual Explain (disabled bu default) - Copy the query to clipboard - Show the source of the query and open in editor - Visualize the duration of the queries with bottom border - Add queries to the timeline (disabled by default) - Limit the number of queries to avoid slowing down the Debugbar. - Exclude paths (eg. for session or vendors) - Show memory usage (disabled by default) ![Query Collector](../img/queries.png) config/debugbar.php ```php 'options' => [ // ... 'db' => [ 'with_params' => true, // Render SQL with the parameters substituted 'exclude_paths' => [ // Paths to exclude entirely from the collector // 'vendor/laravel/framework/src/Illuminate/Session', // Exclude sessions queries ], 'backtrace' => true, // Use a backtrace to find the origin of the query in your files. 'backtrace_exclude_paths' => [], // Paths to exclude from backtrace. (in addition to defaults) 'timeline' => false, // Add the queries to the timeline 'duration_background' => true, // Show shaded background on each query relative to how long it took to execute. 'explain' => [ // Show EXPLAIN output on queries 'enabled' => false, ], 'hints' => false, // Show hints for common mistakes 'show_copy' => true, // Show copy button next to the query, 'slow_threshold' => false, // Only track queries that last longer than this time in ms 'memory_usage' => false, // Show queries memory usage 'soft_limit' => 100, // After the soft limit, no parameters/backtrace are captured 'hard_limit' => 500, // After the hard limit, queries are ignored ], // ... ], ``` ### On-demand query EXPLAIN¶ v3.14.0 options.db.explain Enable the `options.db.explain` option to run on-demand EXPLAIN queries for any SELECT query in the Debugbar. This will update in the interface. You also have an option to navigate to mysqlexplain.com for a visual explain. ![Query On-demand Explain](../img/query-explain.gif) ### Query limits¶ v3.10.0 options.db.soft\_limit: 100 options.db.hard\_limit: 500 With Query Hard & Soft limits, you can reduce the amount of queries shown by default. When the soft limit is reached, bindings will be excluded. When the hard limit is reached, the queries are excluded altogether to prevent loading too much data. If you want to avoid any limits, you can set the option to `null` ![Query Limits](../img/query-limits.png) Messages¶ --------- v1.0 collectors.messages The Message collectors gathers all messages from `debug()` calls and anything written to the logs. You can pass multiple parameters to `debug()`, even complex object. ### Trace¶ When calling `debug()`, the source of the call is shown and can be opened with your IDE. v3.10.0 options.messages.trace ![Messages Collector](../img/messages.png) Logger¶ ------- v1.0 collectors.log When the Messages Collector is enabled, Log messages are added to the Messages tab. Otherwise a Monolog tab will show with just the log messages ![Monolog](../img/monolog.png) config/debugbar.php ```php 'options' => [ // ... 'db' => [ 'with_params' => true, // Render SQL with the parameters substituted 'exclude_paths' => [ // Paths to exclude entirely from the collector // 'vendor/laravel/framework/src/Illuminate/Session', // Exclude sessions queries ], 'backtrace' => true, // Use a backtrace to find the origin of the query in your files. 'backtrace_exclude_paths' => [], // Paths to exclude from backtrace. (in addition to defaults) 'timeline' => false, // Add the queries to the timeline 'duration_background' => true, // Show shaded background on each query relative to how long it took to execute. 'explain' => [ // Show EXPLAIN output on queries 'enabled' => false, ], 'hints' => false, // Show hints for common mistakes 'show_copy' => true, // Show copy button next to the query, 'slow_threshold' => false, // Only track queries that last longer than this time in ms 'memory_usage' => false, // Show queries memory usage 'soft_limit' => 100, // After the soft limit, no parameters/backtrace are captured 'hard_limit' => 500, // After the hard limit, queries are ignored ], // ... ], ``` Views¶ ------ v1.0 collectors.views The ViewCollector shows views and has the following features: * Show used templates and source * Optionally add them to the timeline * Group similar views (useful for components) * Exclude folders (eg. for Filament or other vendors) * Optionally show data (this can be resource heavy) ![ViewCollector](../img/views.png) ```php 'options' => [ 'views' => [ 'timeline' => false, // Add the views to the timeline (Experimental) 'data' => false, //true for all data, 'keys' for only names, false for no parameters. 'group' => 50, // Group duplicate views. Pass value to auto-group, or true/false to force 'exclude_paths' => [ // Add the paths which you don't want to appear in the views 'vendor/filament' // Exclude Filament components by default ], ], ] ``` Timeline¶ --------- v1.0 collectors.time ![Timeline Collector](../img/timeline.png) config/debugbar.php ```php 'options' => [ 'time' => [ 'memory_usage' => false, // Calculated by subtracting memory start and end, it may be inaccurate ], ] ``` Route¶ ------ v1.0 collectors.route This shows the current route and middleware. ![RouteCollector](../img/route.png) config/debugbar.php ```php 'options' => [ 'route' => [ 'label' => true, // show complete route on bar ], ], ``` Exceptions¶ ----------- v1.0 collectors.exceptions Show any errors from the application, including traces. You can manually add exceptions by calling `debugbar()->addThrowable($throwable);` ![ExceptionCollector](../img/exceptions.png) Session¶ -------- v1.0 collectors.phpinfo false A simple widget showing the current PHP Version. ![Session Collector](../img/session.png) Request¶ -------- v1.0 collectors.request Show Request info, like headers, data, cookies etc. Sensitive data is hidden by default, but you can add your own sensitive data to the config. ![Request Collector](../img/request.png) config/debugbar.php ```php 'options' => [ 'symfony_request' => [ 'hiddens' => [], // hides sensitive values using array paths, example: request_request.password ], ], ``` Livewire¶ --------- v3.3.3 collectors.livewire Show the Livewire components that are rendered on the page. ![Livewire Collector](../img/livewire.png) PHP Info¶ --------- v1.0 collectors.phpinfo A simple widget showing the current PHP Version. ![PhpInfo Collector](../img/phpinfo.png) Gate¶ ----- v2.1.0 collectors.gate false The Gate Collector shows the checks that have passed or failed. ![Gate Collector](../img/gate.png) Events¶ ------- v1.0 collectors.events This is similar to the Timeline buts adds all events. This can be a lot of data, so use with caution. ![Events](../img/events.gif) config/debugbar.php ```php 'options' => [ 'events' => [ 'data' => false, // collect events data, listeners ], ], ``` Auth¶ ----- v1.2.2 collectors.auth false A widget showing the current login status + a collector with more information. ![Auth Collector](../img/auth.png) config/debugbar.php ```php 'options' => [ 'auth' => [ 'show_name' => true, // Also show the users name/email in the debugbar 'show_guards' => true, // Show the guards that are used ], ], ``` Mail¶ ----- v1.0 collectors.mail false A collector showing the sent emails. ![Mail Collector](../img/mail.png) ### Mail Preview¶ v3.12.0 options.mail.show\_body true You can open a rendered preview of the email when the body is attached, by clicking 'View Mail' ![Mail Preview](../img/mail-preview.png) Laravel Info¶ ------------- v1.0 collectors.laravel false A widget showing the current Laravel Version, environment and locale. ![Laravel Collector](../img/laravel-info.png) Memory Usage¶ ------------- v1.0 collectors.memory false Show the Memory Usage of the application config/debugbar.php ```php 'options' => [ 'memory' => [ 'reset_peak' => false, // run memory_reset_peak_usage before collecting 'with_baseline' => false, // Set boot memory usage as memory peak baseline 'precision' => 0, // Memory rounding precision ], ] ``` ![Memory Collector](../img/memory.png) Config¶ ------- v3.0 collectors.config false Warning Be careful when turning this on, as it can expose sensitive credentials. Make sure your app is not publicly available. Shows the loaded configuration values. ![Config Collector](../img/config.png) Cache¶ ------ v3.0.0 collectors.cache false Show the hits/misses of the Cache in a Timeline. ![Cache Collector](../img/cache.png) config/debugbar.php ```php 'options' => [ 'cache' => [ 'values' => true, // collect cache values ], ], ``` Models¶ ------- collectors.models false Shows how often each Model is loaded. If this is high, you might want move some logic to SQL instead of processing large Collections. ![Models Collector](../img/models.png) Jobs¶ ----- collectors.models false Show the Jobs that are dispatched from this request. ![Jobs Collector](../img/jobs.png) Logs¶ ----- collectors.logs false Show the most recent logs from the log files in storage/logs ![Logs Collector](../img/logs.png) config/debugbar.php ```php 'options' => [ 'logs' => [ 'file' => null, // Additional files ], ], ``` Pennant¶ -------- v3.14.0 collectors.pennant false Shows all the Pennant flags that are checked during this request ![Pennant Collector](../img/pennant.png) Files¶ ------ v1.0 collectors.files false Deprecated This was mainly useful before OPcache was widely used, and this collector could be used for optimizing files. It's deprecated now. ![Files Collector](../img/files.png) Back to top

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/brianirish/laravel-docs-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server