Seguimiento de errores y ralentizaciones en Node + JavaScript utilizando Sentry

Rate this content
Bookmark

Repasaremos la configuración de Sentry paso a paso para obtener visibilidad en nuestro frontend y backend. Una vez integrado, rastrearemos y solucionaremos errores y transacciones que se muestren en Sentry desde nuestros servicios para comprender por qué/dónde/cómo ocurrieron errores y ralentizaciones en nuestro código de aplicación.

FAQ

Sentry es una herramienta de monitoreo de aplicaciones que ayuda a los desarrolladores a rastrear errores, excepciones y problemas de rendimiento en aplicaciones de Node y JavaScript. Ofrece visibilidad y contexto sobre los problemas para solucionarlos eficazmente.

Para comenzar a utilizar Sentry, debes registrarte en la plataforma en sentry.io/signup, crear una organización y configurar proyectos para tus aplicaciones de React y Express. Después, puedes instalar el SDK de Sentry utilizando npm o yarn e inicializarlo en tu aplicación.

Sentry ayuda a identificar y resolver una variedad de problemas como bloqueos de la aplicación, errores no capturados, excepciones, ralentizaciones en la carga de páginas y problemas de rendimiento relacionados con el backend o el frontend.

Sentry se integra con estas herramientas para mejorar el flujo de trabajo de desarrollo. Por ejemplo, puede enviar alertas de errores directamente a Slack, crear y asignar incidencias automáticamente en JIRA, y vincularse con commits en GitHub para identificar el origen de los errores.

Los mapas de origen son archivos que ayudan a desofuscar y depurar código JavaScript minificado. Sentry utiliza los mapas de origen para proporcionar trazas de pila legibles y detalladas, facilitando la identificación y corrección de errores en el código.

Puedes configurar alertas en Sentry para recibir notificaciones en tiempo real sobre problemas en tus aplicaciones. Estas alertas pueden configurarse para criterios específicos y enviarse a través de canales como email, Slack o incluso integrarse con sistemas de gestión de incidentes como PagerDuty.

Sí, Sentry es efectivo en entornos de microservicios. Permite rastrear transacciones y errores a través de diferentes servicios y ofrece una visión integrada del rendimiento y problemas en toda la arquitectura de microservicios.

Neil Manvar
Neil Manvar
53 min
15 Feb, 2022

Comments

Sign in or register to post your comment.

Video Summary and Transcription

La Masterclass de hoy se centró en la monitorización de aplicaciones utilizando Sentry. Se destacó la importancia de rastrear errores, ralentizaciones y versiones, junto con el proceso de integración para aplicaciones React, Express y Node.js. Se demostraron las capacidades de depuración de Sentry, incluyendo la identificación de errores, ralentizaciones y problemas en el backend. También se abordó la monitorización de versiones, la consulta de datos y la visualización de información, junto con la integración de Sentry con herramientas de flujo de trabajo. En la sesión de preguntas y respuestas se trataron diversos temas, incluyendo el uso de Sentry en diferentes entornos y su integración con otras herramientas.

1. Introducción al Monitoreo de Aplicaciones

Short description:

Hoy discutiremos el seguimiento de la experiencia del usuario en aplicaciones de Node y JavaScript, incluyendo bloqueos, errores, excepciones y cargas de página lentas. Integraremos Sentry, resolveremos errores y ralentizaciones, y entenderemos cómo se ven afectadas las versiones. Siéntanse libres de hacer preguntas.

Muy bien, empecemos. En primer lugar, gracias a todos por tomar el tiempo para asistir a esta masterclass. Solo quiero confirmar si todos pueden escucharme. Si alguien puede simplemente decirme sí en el chat, sería fantástico. Genial, gracias. Lo aprecio, a todos.

Muy bien, hoy vamos a hablar sobre cómo podemos rastrear nuestra experiencia de usuario en nuestras aplicaciones de Node y JavaScript, específicamente cuando se trata de bloqueos, errores, excepciones, cargas de página lentas, renderizaciones, y todas esas cosas en las que estarías interesado si fueras el desarrollador que escribió este código, y lo puso en producción.

Además, obtendremos la visibilidad y el contexto que necesitamos desde el lado de la aplicación para poder saber por qué ocurren estos problemas, dónde en el código ocurren, a quién le ocurren y solucionarlos y avanzar.

A modo de introducción, mi nombre es Neil Manbar. Vengo de un fondo de desarrollo front-end y ahora dirijo el equipo de ingeniería de soluciones en Sentry, donde ayudo a otros desarrolladores front-end y desarrolladores de backend a usar Sentry y conocer sus problemas para que puedan solucionarlos, que es el ejercicio que vamos a hacer hoy y estoy muy emocionado al respecto.

Entonces, rápidamente, repasemos la agenda. Primero, quiero demostrar el problema. Quiero mostrar dónde están las brechas cuando estás desarrollando una aplicación de navegador que se comunica, digamos, con un backend Express, y cuando ocurren problemas, dónde están las brechas específicas en visibilidad y contexto y por qué necesitas una verdadera herramienta de monitoreo de aplicaciones dentro de tus aplicaciones.

Luego procederemos a integrar Sentry, específicamente introducir el SDK en nuestra aplicación para el front-end. También configuraremos los mapas de origen para obtener una traza legible. Y luego pasaremos por todos los diferentes casos de uso. Usaremos Sentry para solucionar errores. Le diremos qué está sucediendo, obtendremos todo el contexto que necesitamos, el quién, qué, cuándo, dónde y por qué para poder hacer algo al respecto. Y haremos lo mismo para las ralentizaciones. Y luego, como desarrollador, estás lanzando versiones, estás lanzando nuevas compilaciones. Estamos tratando de hacer esto a un ritmo cada vez mayor. Sentry también te dirá cómo todo esto se une en términos de versiones, si tu versión es adoptada, si tiene nuevos errores, si tiene ralentizaciones, etc. Y luego cualquier dato que enviemos a la plataforma, podremos analizarlo, consultar y crear paneles de control, y lo explicaré al final.

Si tienen alguna pregunta, no duden en escribirla en el chat. También responderé preguntas al final.

2. Conceptos básicos del Monitoreo de Aplicaciones

Short description:

En esta parte, discutiremos la necesidad de monitorear aplicaciones y los desafíos que enfrentan los desarrolladores sin él. Exploraremos las trazas de pila ilegibles, las ralentizaciones y los errores que a menudo pasan desapercibidos. También destacaremos la importancia del contexto y cómo Sentry puede proporcionar las herramientas necesarias para identificar y resolver problemas. A lo largo de la masterclass, nos centraremos en solucionar errores, ralentizaciones y realizar un seguimiento de la adopción de las versiones. Para seguir el contenido, crea tus propias aplicaciones Express y React, regístrate en Sentry y crea dos proyectos. Sumergámonos en la documentación y exploremos la integración en la aplicación PlantStore.

Entonces, ¿por qué el monitoreo de aplicaciones, y por qué realmente lo necesito en mis aplicaciones? En lugar de simplemente proporcionarles un montón de texto, voy a mostrarles el problema. Aquí tengo mi aplicación, y básicamente es un front-end de React que se comunica con un paquete de Express. Voy a dejar la consola abierta. Voy a actualizar y, de vez en cuando, se bloqueará, y ahí lo tienen. Y cuando se bloquea, básicamente tenemos esta traza de pila ilegible. Realmente no sabemos qué está pasando. Ni siquiera sabemos si ocurrió, a menos que el usuario nos lo informe, o eventualmente descubramos que esto está sucediendo y luego lo reproduzcamos, y luego obtenemos esta información aquí.

Además, digamos que cuando esto funciona, también hay ralentizaciones. Aquí es lento. ¿Es por el back-end? ¿Es por el front-end? ¿Es por mi código de renderizado? ¿Es por alguna ralentización en la capa de la database? No lo sé. Así que agreguemos algunos elementos al carrito, y luego procederemos a pagar. Y cuando lo hacemos, también hubo cierta lentitud, y parece que también hubo un error. Así que ahora voy a resumir lo que sucedió aquí. Si observamos, lo primero es que nos quedamos con una traza de pila ilegible. Estaba minimizada. No sabíamos qué estaba pasando, e incluso ni siquiera sabíamos del error en primer lugar. Lo mismo con la ralentización. Ni siquiera sabíamos de la ralentización a menos que un usuario nos lo informara, y luego lo reprodujéramos, y luego tuviéramos que buscar en todas las herramientas de perfilado y todo ese tipo de cosas. Y además, también hubo un error con la ralentización. Entonces, en el front-end no tenemos la visibilidad que necesitamos. Y estamos limitados a la reproducción. Y en el back-end, si no estamos utilizando una herramienta de monitoreo de aplicaciones, terminamos teniendo que buscar en los registros, armar consultas, y luego armar esto desde el exterior en lugar de desde el interior de la aplicación.

Así que vamos a mostrar lo que un desarrollador realmente querría y necesitaría cuando se trata de este tipo de cosas. Necesitarías el contexto. Necesitas un SDK que esté presente en el código que envía información. Y luego recibirás una alerta cuando haya un problema. Tu equipo lo sabrá. Y luego podemos obtener el contexto de la capa de la aplicación, quién, qué, cuándo, dónde y por qué, que mostraré que Sentry muestra. Y sería genial si incluso pudiéramos identificar qué confirmación o cambio de código causó esto. Así podríamos asignarlo al desarrollador correcto, y luego avanzar con esto y volver a un estado exitoso. Entonces, este es el flujo de trabajo que Sentry podrá proporcionarte. Enviaremos errores, transacciones y sesiones. Recibirás una alerta cuando algo salga mal, lo sabrás, obtendrás el contexto que necesitas y podrás avanzar. Pasaremos por todo esto, pero resolveremos errores. Resolveremos ralentizaciones. Veremos si nuestra última versión se adoptó correctamente. Crearemos paneles de control, analizaremos los datos. Y como desarrollador, uso Slack. Uso GitHub. Uso JIRA. Uso mis propias herramientas, y también uso alrededor de cien de estas herramientas juntas. Para aquellos de ustedes que deseen seguir el contenido, les sugiero que creen su propia aplicación Express utilizando Express Generator, y lo mismo con React, pueden crear una aplicación React. Y luego regístrense en Sentry. He insertado un enlace aquí, sentry.io/signup, y crearemos dos proyectos. Voy a usar mi propia aplicación. Es un poco más complicada. Por eso sugiero que ustedes simplemente usen Express Generator o creen una aplicación React y comiencen desde una aplicación completamente nueva. Registrarse en Sentry es gratuito. Simplemente vayan a Sentry.io/signup, creen una organización y luego creen proyectos, uno para su React, uno para su Express. Antes de meternos en todo esto, voy a resaltar toda la documentación, y luego pasaré por este ejercicio con todos ustedes. Mostraré cómo se integra en esa aplicación PlantStore que estaba mostrando.

QnA

Watch more workshops on topic

Cómo Resolver Problemas del Mundo Real con Remix
Remix Conf Europe 2022Remix Conf Europe 2022
195 min
Cómo Resolver Problemas del Mundo Real con Remix
Featured Workshop
Michael Carter
Michael Carter
- ¿Errores? Cómo renderizar y registrar tus errores del servidor y del clientea - Cuándo devolver errores vs lanzar excepcionesb - Configurar servicios de registro como Sentry, LogRocket y Bugsnag- ¿Formularios? Cómo validar y manejar formularios de varias páginasa - Usar zod para validar los datos del formulario en tu acciónb - Pasar por formularios de varias páginas sin perder datos- ¿Atascado? Cómo solucionar errores o funciones faltantes en Remix para que puedas continuara - Usar patch-package para solucionar rápidamente tu instalación de Remixb - Mostrar herramienta para gestionar múltiples parches y seleccionar solicitudes de extracción abiertas- ¿Usuarios? Cómo manejar aplicaciones de varios inquilinos con Prismaa - Determinar el inquilino por el host o por el usuariob - Base de datos múltiples o base de datos única/múltiples esquemasc - Asegura que los datos del inquilino siempre estén separados de los demás
Monitoreo 101 para Desarrolladores de React
React Advanced Conference 2023React Advanced Conference 2023
112 min
Monitoreo 101 para Desarrolladores de React
Top Content
WorkshopFree
Lazar Nikolov
Sarah Guthals
2 authors
Si encontrar errores en tu proyecto frontend es como buscar una aguja en un pajar de código, entonces el monitoreo de errores de Sentry puede ser tu detector de metales. Aprende los conceptos básicos del monitoreo de errores con Sentry. Ya sea que estés ejecutando un proyecto de React, Angular, Vue, o simplemente JavaScript “vainilla”, ve cómo Sentry puede ayudarte a encontrar el quién, qué, cuándo y dónde detrás de los errores en tu proyecto frontend.
Masterclass de Node.js
Node Congress 2023Node Congress 2023
109 min
Masterclass de Node.js
Top Content
Workshop
Matteo Collina
Matteo Collina
¿Alguna vez has tenido dificultades para diseñar y estructurar tus aplicaciones Node.js? Construir aplicaciones que estén bien organizadas, sean probables y extensibles no siempre es fácil. A menudo puede resultar ser mucho más complicado de lo que esperas. En este evento en vivo, Matteo te mostrará cómo construye aplicaciones Node.js desde cero. Aprenderás cómo aborda el diseño de aplicaciones y las filosofías que aplica para crear aplicaciones modulares, mantenibles y efectivas.

Nivel: intermedio
Construye y Despliega un Backend con Fastify y Platformatic
JSNation 2023JSNation 2023
104 min
Construye y Despliega un Backend con Fastify y Platformatic
WorkshopFree
Matteo Collina
Matteo Collina
Platformatic te permite desarrollar rápidamente APIs GraphQL y REST con un esfuerzo mínimo. La mejor parte es que también te permite aprovechar todo el potencial de Node.js y Fastify cuando lo necesites. Puedes personalizar completamente una aplicación de Platformatic escribiendo tus propias características y complementos adicionales. En el masterclass, cubriremos tanto nuestros módulos de código abierto como nuestra oferta en la nube:- Platformatic OSS (open-source software) — Herramientas y bibliotecas para construir rápidamente aplicaciones robustas con Node.js (https://oss.platformatic.dev/).- Platformatic Cloud (actualmente en beta) — Nuestra plataforma de alojamiento que incluye características como aplicaciones de vista previa, métricas integradas e integración con tu flujo de Git (https://platformatic.dev/).
En este masterclass aprenderás cómo desarrollar APIs con Fastify y desplegarlas en la nube de Platformatic.
0 a Auth en una Hora Usando NodeJS SDK
Node Congress 2023Node Congress 2023
63 min
0 a Auth en una Hora Usando NodeJS SDK
WorkshopFree
Asaf Shen
Asaf Shen
La autenticación sin contraseña puede parecer compleja, pero es fácil de agregar a cualquier aplicación utilizando la herramienta adecuada.
Mejoraremos una aplicación JS de pila completa (backend de Node.JS + frontend de React) para autenticar usuarios con OAuth (inicio de sesión social) y contraseñas de un solo uso (correo electrónico), incluyendo:- Autenticación de usuario - Administrar interacciones de usuario, devolver JWT de sesión / actualización- Gestión y validación de sesiones - Almacenar la sesión para solicitudes de cliente posteriores, validar / actualizar sesiones
Al final del masterclass, también tocaremos otro enfoque para la autenticación de código utilizando Flujos Descope en el frontend (flujos de arrastrar y soltar), manteniendo solo la validación de sesión en el backend. Con esto, también mostraremos lo fácil que es habilitar la biometría y otros métodos de autenticación sin contraseña.
Tabla de contenidos- Una breve introducción a los conceptos básicos de autenticación- Codificación- Por qué importa la autenticación sin contraseña
Requisitos previos- IDE de tu elección- Node 18 o superior
Construyendo un Servidor Web Hiper Rápido con Deno
JSNation Live 2021JSNation Live 2021
156 min
Construyendo un Servidor Web Hiper Rápido con Deno
WorkshopFree
Matt Landers
Will Johnston
2 authors
Deno 1.9 introdujo una nueva API de servidor web que aprovecha Hyper, una implementación rápida y correcta de HTTP para Rust. El uso de esta API en lugar de la implementación std/http aumenta el rendimiento y proporciona soporte para HTTP2. En este masterclass, aprende cómo crear un servidor web utilizando Hyper en el fondo y mejorar el rendimiento de tus aplicaciones web.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Vue: Actualizaciones de Características
Vue.js London 2023Vue.js London 2023
44 min
Vue: Actualizaciones de Características
Top Content
El creador de Vue js da una actualización sobre las nuevas características de la tecnología.
Es una jungla ahí fuera: ¿Qué está pasando realmente dentro de tu carpeta Node_Modules?
Node Congress 2022Node Congress 2022
26 min
Es una jungla ahí fuera: ¿Qué está pasando realmente dentro de tu carpeta Node_Modules?
Top Content
¿Sabes qué está pasando realmente en tu carpeta node_modules? Los ataques a la cadena de suministro de software han explotado en los últimos 12 meses y solo están acelerándose en 2022 y más allá. Profundizaremos en ejemplos de recientes ataques a la cadena de suministro y qué pasos concretos puedes tomar para proteger a tu equipo de esta amenaza emergente.
Puedes consultar las diapositivas de la charla de Feross aquí.
Hacia una Biblioteca Estándar para Runtimes de JavaScript
Node Congress 2022Node Congress 2022
34 min
Hacia una Biblioteca Estándar para Runtimes de JavaScript
Top Content
Puedes revisar las diapositivas de la charla de James aquí.
ESM Loaders: Mejorando la carga de módulos en Node.js
JSNation 2023JSNation 2023
22 min
ESM Loaders: Mejorando la carga de módulos en Node.js
El soporte nativo de ESM para Node.js fue una oportunidad para el proyecto de Node.js de lanzar soporte oficial para mejorar la experiencia de carga de módulos, permitiendo casos de uso como la transpilación sobre la marcha, la sustitución de módulos, el soporte para cargar módulos desde HTTP y la monitorización.
Aunque CommonJS tiene soporte para todo esto, nunca fue oficialmente compatible y se hacía mediante hackeo del código de ejecución de Node.js. ESM ha solucionado todo esto. Analizaremos la arquitectura de la carga de ESM en Node.js y discutiremos la API del cargador que lo admite. También veremos características avanzadas como la concatenación de cargadores y la ejecución fuera de hilo.
Diagnostics de Node.js listos para usar
Node Congress 2022Node Congress 2022
34 min
Diagnostics de Node.js listos para usar
En los primeros años de Node.js, los diagnósticos y la depuración eran puntos problemáticos considerables. Las versiones modernas de Node han mejorado considerablemente en estas áreas. Características como seguimiento de pila asíncrono, capturas de montón y perfilado de CPU ya no requieren módulos de terceros o modificaciones en el código fuente de la aplicación. Esta charla explora las diversas características de diagnóstico que se han incorporado recientemente a Node.
Puedes consultar las diapositivas de la charla de Colin aquí. 
Compatibilidad con Node.js en Deno
Node Congress 2022Node Congress 2022
34 min
Compatibilidad con Node.js en Deno
¿Puede Deno ejecutar aplicaciones y bibliotecas creadas para Node.js? ¿Cuáles son los compromisos? ¿Cómo funciona? ¿Qué sigue?