Habilita la biblioteca
Puedes enviar informes de errores a Error Reporting desde aplicaciones PHP mediante la biblioteca de Error Reporting para PHP.
Error Reporting está integrado a algunos servicios de Google Cloud, como App Engine, Compute Engine y Google Kubernetes Engine. Error Reporting muestra los errores que registran las aplicaciones que se ejecutan en esos servicios en Cloud Logging. Para obtener más información, ve a Ejecuta en Google Cloud Platform en esta página.
También puedes enviar datos de errores a Error Reporting mediante Logging. Para obtener información sobre los requisitos de formato de datos, consulta Dale formato a los mensajes de error en Logging.
Antes de comenzar
- Accede a tu Cuenta de Google.
Si todavía no tienes una cuenta, regístrate para obtener una nueva.
-
En la página del selector de proyectos de Google Cloud Console, selecciona o crea un proyecto de Google Cloud.
-
Comprueba que la facturación esté habilitada en tu proyecto.
- Habilita las Error Reporting API .
Instala la biblioteca cliente
La biblioteca de Error Reporting para PHP te permite supervisar y ver errores informados por las aplicaciones PHP que se ejecutan prácticamente en cualquier sitio.
Para obtener más información sobre la instalación, lee la documentación de la biblioteca de Error Reporting para PHP. También puedes informar problemas con el seguimiento de problemas.
Configura la biblioteca cliente
Puedes personalizar el comportamiento de la biblioteca d Error Reporting para PHP. Consulta la configuración de la biblioteca para obtener una lista de las opciones de configuración posibles.
Informa errores
1. Instala las bibliotecas de nube con el siguiente comando:
$ composer require google/cloud-error-reporting1. Agrega la siguiente línea al
php.ini
, en el que PROJECT_DIR es la ruta de acceso absoluta al directorio raíz de tu proyecto:
auto_prepend_file='PROJECT_DIR/vendor/google/cloud-error-reporting/src/prepend.php'1. Configura la variable de entorno GOOGLE_CLOUD_PROJECT con el nombre de tu proyecto de Google Cloud.
Este archivo antepuesto instalará un controlador de excepciones y un controlador de errores que envía errores a Error Reporting de forma automática.
Ejecuta en Google Cloud
El uso de la biblioteca de Error Reporting para PHP requiere la función de escritor de Error Reporting de la administración de identidades y accesos. La mayoría de las plataformas de computación de Google Cloud proporcionan esta función de forma predeterminada.
Puedes configurar Error Reporting para PHP en los siguientes entornos de Google Cloud.
Entorno flexible de App Engine
App Engine otorga la función de escritor de Error Reporting de forma predeterminada.
La biblioteca de Error Reporting para PHP se puede usar sin necesidad de proporcionar credenciales de forma explícita.
Para habilitar Error Reporting en el entorno flexible de App Engine, sigue estos pasos:
Instala las bibliotecas necesarias con el siguiente comando:
$ composer require google/cloud-error-reporting
Agrega la siguiente línea a la sección
runtime_config
enapp.yaml
:
Luego, la biblioteca recopila de manera automática todos los errores y las excepciones no detectadas en Error Reporting. Si utilizas un marco de trabajo web que instala sus propios controladores de excepciones, consulta la sección de integraciones de marcos de trabajo para obtener más información.
Google Kubernetes Engine
En GKE debes agregar el permiso de acceso de cloud-platform
cuando creas el clúster, como se muestra en el siguiente comando de ejemplo:
gcloud container clusters create example-cluster-name --scopes https://www.googleapis.com/auth/cloud-platform
Compute Engine
Cuando uses las instancias de VM de Compute Engine, agrega el permiso de acceso cloud-platform
a cada instancia. Si creas una instancia nueva a través de Google Cloud Console, puedes hacerlo en la sección Identidad y acceso a la API del panel Crear Instancia. Usa la cuenta de servicio predeterminada de Compute Engine o una cuenta de servicio diferente y selecciona Permitir acceso total a las API de Cloud en la sección Identidad y acceso a la API. Con cualquier cuenta de servicio que selecciones, asegúrate de que se le haya otorgado la función de escritor de Error Reporting en la sección IAM y administración de Cloud Console.
Ejecuta de forma local y en otros lugares
Para usar la biblioteca de Error Reporting para PHP fuera de Google Cloud, incluso si lo ejecutas en tu propia estación de trabajo, en las computadoras del centro de datos o en las instancias de VM de otro proveedor de servicios en la nube, debes proporcionar tu ID del proyecto de Google Cloud y las credenciales adecuadas de la cuenta de servicio directamente a la biblioteca de Error Reporting para PHP.
Puedes crear y obtener credenciales de cuentas de servicio de forma manual. Cuando especifiques el campo Función, usa la función de escritor de Error Reporting. Para obtener más información sobre las funciones de la administración de identidades y accesos, consulta la Guía de control de acceso.
Ve informes de errores
Después de la implementación, puedes ver los informes de errores en el panel de Error Reporting dentro de Cloud Console.
Ir al panel de Error Reporting
Para obtener más información, consulta Cómo visualizar errores.
Integraciones de marcos de trabajo
Algunos marcos de trabajo web anulan el controlador de excepciones. Los siguientes son ejemplos para habilitar Error Reporting con Laravel y Symfony. Para otros marcos de trabajo, puedes usar Google\Cloud\ErrorReporting\Bootstrap::exceptionHandler
como el controlador de excepciones.
Laravel
Edita la función report
en el archivo app/Exceptions/Handler.php
de la siguiente manera:
También debes agregar una instrucción use
de una línea al comienzo del archivo:
use Google\Cloud\ErrorReporting\Bootstrap;
Symfony
Crea un archivo nuevo src/AppBundle/EventSubscriber/ExceptionSubscriber.php
con el siguiente contenido: