Laravel Telescope
- Introducción
- Instalación
- Actualizando Telescope
- Filtrado
- Etiquetado
-
Monitores Disponibles
- Monitor de Lotes
- Monitor de Caché
- Monitor de Comando
- Monitor de Volcado
- Monitor de Evento
- Monitor de Excepción
- Monitor de Puerta
- Monitor de Cliente HTTP
- Monitor de Trabajo
- Monitor de Registro
- Monitor de Correo
- Monitor de Modelo
- Monitor de Notificación
- Monitor de Consulta
- Monitor de Redis
- Monitor de Solicitud
- Monitor de Programa
- Monitor de Vista
- Mostrando Avatares de Usuario
Introducción
Laravel Telescope es un compañero maravilloso para tu entorno de desarrollo local de Laravel. Telescope proporciona información sobre las solicitudes que llegan a tu aplicación, excepciones, entradas de registro, consultas a la base de datos, trabajos en cola, correo, notificaciones, operaciones de caché, tareas programadas, volcado de variables y más.
Instalación
Puedes usar el gestor de paquetes Composer para instalar Telescope en tu proyecto Laravel:
composer require laravel/telescope
Después de instalar Telescope, publica sus activos y migraciones utilizando el comando Artisan telescope:install
. Después de instalar Telescope, también debes ejecutar el comando migrate
para crear las tablas necesarias para almacenar los datos de Telescope:
php artisan telescope:install php artisan migrate
Finalmente, puedes acceder al panel de control de Telescope a través de la ruta /telescope
.
Instalación Solo Local
Si planeas usar Telescope solo para ayudar en tu desarrollo local, puedes instalar Telescope utilizando el flag --dev
:
composer require laravel/telescope --dev php artisan telescope:install php artisan migrate
Después de ejecutar telescope:install
, deberías eliminar el registro del proveedor de servicios TelescopeServiceProvider
del archivo de configuración bootstrap/providers.php
de tu aplicación. En su lugar, registra manualmente los proveedores de servicios de Telescope en el método register
de tu clase App\Providers\AppServiceProvider
. Nos aseguraremos de que el entorno actual sea local
antes de registrar los proveedores:
/** * Register any application services. */ public function register(): void { if ($this->app->environment('local') && class_exists(\Laravel\Telescope\TelescopeServiceProvider::class)) { $this->app->register(\Laravel\Telescope\TelescopeServiceProvider::class); $this->app->register(TelescopeServiceProvider::class); } }
Finalmente, también deberías evitar que el paquete Telescope sea auto-descubierto añadiendo lo siguiente a tu archivo composer.json
:
"extra": { "laravel": { "dont-discover": [ "laravel/telescope" ] } },
Configuración
Después de publicar los activos de Telescope, su archivo de configuración principal se ubicará en config/telescope.php
. Este archivo de configuración te permite configurar tus opciones de vigilancia. Cada opción de configuración incluye una descripción de su propósito, así que asegúrate de explorar este archivo a fondo.
Si lo deseas, puedes deshabilitar completamente la recopilación de datos de Telescope utilizando la opción de configuración enabled
:
'enabled' => env('TELESCOPE_ENABLED', true),
Poda de Datos
Sin eliminar, la tabla telescope_entries
puede acumular registros muy rápidamente. Para mitigar esto, debes programar el comando Artisan telescope:prune
para que se ejecute a diario:
use Illuminate\Support\Facades\Schedule; Schedule::command('telescope:prune')->daily();
Por defecto, se eliminarán todas las entradas que tengan más de 24 horas. Puedes usar la opción hours
al llamar al comando para determinar cuánto tiempo retener los datos de Telescope. Por ejemplo, el siguiente comando eliminará todos los registros creados hace más de 48 horas:
use Illuminate\Support\Facades\Schedule; Schedule::command('telescope:prune --hours=48')->daily();
Autorización de Tablero
El panel de control de Telescope se puede acceder a través de la ruta /telescope
. Por defecto, solo podrás acceder a este panel en el entorno local
. Dentro de tu archivo app/Providers/TelescopeServiceProvider.php
, hay una definición de puerta de autorización. Esta puerta de autorización controla el acceso a Telescope en entornos no locales. Puedes modificar esta puerta según sea necesario para restringir el acceso a tu instalación de Telescope:
use App\Models\User; /** * Register the Telescope gate. * * This gate determines who can access Telescope in non-local environments. */ protected function gate(): void { Gate::define('viewTelescope', function (User $user) { return in_array($user->email, [ 'taylor@laravel.com', ]); }); }
Debes asegurarte de cambiar la variable de entorno APP_ENV
a production
en tu entorno de producción. De lo contrario, tu instalación de Telescope estará disponible públicamente.
Actualizando Telescope
Al actualizar a una nueva versión principal de Telescope, es importante que revises cuidadosamente la guía de actualización. Además, al actualizar a cualquier nueva versión de Telescope, debes volver a publicar los activos de Telescope:
php artisan telescope:publish
Para mantener los recursos actualizados y evitar problemas en futuras actualizaciones, puedes agregar el comando vendor:publish --tag=laravel-assets
a los scripts post-update-cmd
en el archivo composer.json
de tu aplicación:
{ "scripts": { "post-update-cmd": [ "@php artisan vendor:publish --tag=laravel-assets --ansi --force" ] } }
Filtrado
Entradas
Puedes filtrar los datos que se registran por Telescope a través de la función anónima filter
que se define en tu clase App\Providers\TelescopeServiceProvider
. Por defecto, esta función anónima registra todos los datos en el entorno local
y excepciones, trabajos fallidos, tareas programadas y datos con etiquetas monitoreadas en todos los demás entornos:
use Laravel\Telescope\IncomingEntry; use Laravel\Telescope\Telescope; /** * Register any application services. */ public function register(): void { $this->hideSensitiveRequestDetails(); Telescope::filter(function (IncomingEntry $entry) { if ($this->app->environment('local')) { return true; } return $entry->isReportableException() || $entry->isFailedJob() || $entry->isScheduledTask() || $entry->isSlowQuery() || $entry->hasMonitoredTag(); }); }
Lotes
Mientras que la función anónima filter
filtra datos para entradas individuales, puedes usar el método filterBatch
para registrar una función anónima que filtre todos los datos para una solicitud dada o un comando de consola. Si la función anónima devuelve true
, todas las entradas son registradas por Telescope:
use Illuminate\Support\Collection; use Laravel\Telescope\IncomingEntry; use Laravel\Telescope\Telescope; /** * Register any application services. */ public function register(): void { $this->hideSensitiveRequestDetails(); Telescope::filterBatch(function (Collection $entries) { if ($this->app->environment('local')) { return true; } return $entries->contains(function (IncomingEntry $entry) { return $entry->isReportableException() || $entry->isFailedJob() || $entry->isScheduledTask() || $entry->isSlowQuery() || $entry->hasMonitoredTag(); }); }); }
Etiquetado
Telescope te permite buscar entradas por "etiqueta". A menudo, las etiquetas son nombres de clase de modelo Eloquent o identificadores de usuario autenticados que Telescope añade automáticamente a las entradas. Ocasionalmente, es posible que desees adjuntar tus propias etiquetas personalizadas a las entradas. Para lograr esto, puedes usar el método Telescope::tag
. El método tag
acepta una función anónima que debe devolver un array de etiquetas. Las etiquetas devueltas por la función anónima se fusionarán con las etiquetas que Telescope añadiría automáticamente a la entrada. Típicamente, deberías llamar al método tag
dentro del método register
de tu clase App\Providers\TelescopeServiceProvider
:
use Laravel\Telescope\IncomingEntry; use Laravel\Telescope\Telescope; /** * Register any application services. */ public function register(): void { $this->hideSensitiveRequestDetails(); Telescope::tag(function (IncomingEntry $entry) { return $entry->type === 'request' ? ['status:'.$entry->content['response_status']] : []; }); }
Monitores Disponibles
Los "observadores" de Telescope recopilan datos de la aplicación cuando se ejecuta una solicitud o un comando de consola. Puedes personalizar la lista de observadores que te gustaría habilitar dentro de tu archivo de configuración config/telescope.php
:
'watchers' => [ Watchers\CacheWatcher::class => true, Watchers\CommandWatcher::class => true, ... ],
Algunos observadores también te permiten proporcionar opciones de personalización adicionales:
'watchers' => [ Watchers\QueryWatcher::class => [ 'enabled' => env('TELESCOPE_QUERY_WATCHER', true), 'slow' => 100, ], ... ],
Monitor de Lotes
El vigilante de lotes registra información sobre los lotes en la cola, incluida la información del trabajo y de la conexión.
Monitor de Caché
El monitor de caché registra datos cuando se accede, pierde, actualiza y olvida una clave de caché.
Monitor de Comando
El vigilante de comandos registra los argumentos, opciones, código de salida y salida cada vez que se ejecuta un comando Artisan. Si deseas excluir ciertos comandos de ser registrados por el vigilante, puedes especificar el comando en la opción ignore
dentro de tu archivo config/telescope.php
:
'watchers' => [ Watchers\CommandWatcher::class => [ 'enabled' => env('TELESCOPE_COMMAND_WATCHER', true), 'ignore' => ['key:generate'], ], ... ],
Monitor de Volcado
El observador de volcados registra y muestra tus volcados de variables en Telescope. Al usar Laravel, las variables pueden volcarse utilizando la función global dump
. La pestaña del observador de volcados debe estar abierta en un navegador para que se registre el volcado; de lo contrario, los volcadors serán ignorados por el observador.
Monitor de Evento
El observador de eventos registra la carga útil, los oyentes y los datos de difusión para cualquier evento despachado por tu aplicación. Los eventos internos del framework Laravel son ignorados por el observador de eventos.
Monitor de Excepción
El observador de excepciones registra los datos y la traza de la pila para cualquier excepción reportable que sea lanzada por tu aplicación.
Monitor de Puerta
El observador de puertas registra los datos y el resultado de las verificaciones de puerta y política por su aplicación. Si desea excluir ciertas habilidades de ser registradas por el observador, puede especificarlas en la opción ignore_abilities
en su archivo config/telescope.php
:
'watchers' => [ Watchers\GateWatcher::class => [ 'enabled' => env('TELESCOPE_GATE_WATCHER', true), 'ignore_abilities' => ['viewNova'], ], ... ],
Monitor de Cliente HTTP
El vigilante del cliente HTTP registra las solicitudes del cliente HTTP salientes realizadas por tu aplicación.
Monitor de Trabajo
El observador de trabajos registra los datos y el estado de cualquier trabajo despachado por tu aplicación.
Monitor de Registro
El observador de registros registra los datos de registro para cualquier registro escrito por tu aplicación.
Por defecto, Telescope solo registrará logs en el nivel error
y superiores. Sin embargo, puedes modificar la opción level
en el archivo de configuración config/telescope.php
de tu aplicación para modificar este comportamiento:
'watchers' => [ Watchers\LogWatcher::class => [ 'enabled' => env('TELESCOPE_LOG_WATCHER', true), 'level' => 'debug', ], // ... ],
Monitor de Correo
El visor de correo te permite ver una vista previa en el navegador de los correos electrónicos enviados por tu aplicación junto con sus datos asociados. También puedes descargar el correo electrónico como un archivo .eml
.
Monitor de Modelo
El vigilante de modelos registra los cambios de modelo siempre que se despache un evento de modelo de Eloquent. Puedes especificar qué eventos de modelo deben ser registrados a través de la opción events
del vigilante:
'watchers' => [ Watchers\ModelWatcher::class => [ 'enabled' => env('TELESCOPE_MODEL_WATCHER', true), 'events' => ['eloquent.created*', 'eloquent.updated*'], ], ... ],
Si deseas registrar el número de modelos hidratados durante una solicitud dada, habilita la opción hydrations
:
'watchers' => [ Watchers\ModelWatcher::class => [ 'enabled' => env('TELESCOPE_MODEL_WATCHER', true), 'events' => ['eloquent.created*', 'eloquent.updated*'], 'hydrations' => true, ], ... ],
Monitor de Notificación
El observador de notificaciones registra todas las notificaciones enviadas por tu aplicación. Si la notificación activa un correo electrónico y tienes habilitado el observador de correo, el correo electrónico también estará disponible para vista previa en la pantalla del observador de correo.
Monitor de Consulta
El reloj de consulta registra el SQL en bruto, los enlaces y el tiempo de ejecución para todas las consultas que son ejecutadas por tu aplicación. El reloj también etiqueta cualquier consulta más lenta que 100 milisegundos como slow
. Puedes personalizar el umbral de consulta lenta utilizando la opción slow
del reloj:
'watchers' => [ Watchers\QueryWatcher::class => [ 'enabled' => env('TELESCOPE_QUERY_WATCHER', true), 'slow' => 50, ], ... ],
Monitor de Redis
El watcher de Redis registra todos los comandos Redis ejecutados por su aplicación. Si está utilizando Redis para almacenamiento en caché, los comandos de caché también serán registrados por el watcher de Redis.
Monitor de Solicitud
El visor de solicitudes registra la solicitud, encabezados, sesión y datos de respuesta asociados con cualquier solicitud manejada por la aplicación. Puedes limitar los datos de respuesta grabados a través de la opción size_limit
(en kilobytes):
'watchers' => [ Watchers\RequestWatcher::class => [ 'enabled' => env('TELESCOPE_REQUEST_WATCHER', true), 'size_limit' => env('TELESCOPE_RESPONSE_SIZE_LIMIT', 64), ], ... ],
Monitor de Programa
El vigilante de programación registra el comando y la salida de cualquier tarea programada ejecutada por tu aplicación.
Monitor de Vista
El observador de vistas registra el nombre, la ruta, los datos y los "compositores" utilizados al renderizar vistas.
Mostrando Avatares de Usuario
El panel de Telescope muestra el avatar del usuario para el usuario que fue autenticado cuando se guardó una entrada dada. Por defecto, Telescope recuperará los avatares utilizando el servicio web Gravatar. Sin embargo, puedes personalizar la URL del avatar registrando un callback en tu clase App\Providers\TelescopeServiceProvider
. El callback recibirá la ID y la dirección de correo electrónico del usuario y debe devolver la URL de la imagen del avatar del usuario:
use App\Models\User; use Laravel\Telescope\Telescope; /** * Register any application services. */ public function register(): void { // ... Telescope::avatar(function (string $id, string $email) { return '/avatars/'.User::find($id)->avatar_path; }); }