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.

This workshop has been presented at Node Congress 2022, check out the latest edition of this JavaScript Conference.

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 2023React Advanced 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.
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.
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

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
The Talk discusses the recent feature updates in Vue 3.3, focusing on script setup and TypeScript support. It covers improvements in defining props using imported types and complex types support. The introduction of generic components and reworked signatures for defined components provides more flexibility and better type support. Other features include automatic inference of runtime props, improved define emits and defined slots, and experimental features like reactive props destructure and define model. The Talk also mentions future plans for Vue, including stabilizing suspense and enhancing computer invalidations.
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
The talk discusses the importance of supply chain security in the open source ecosystem, highlighting the risks of relying on open source code without proper code review. It explores the trend of supply chain attacks and the need for a new approach to detect and block malicious dependencies. The talk also introduces Socket, a tool that assesses the security of packages and provides automation and analysis to protect against malware and supply chain attacks. It emphasizes the need to prioritize security in software development and offers insights into potential solutions such as realms and Deno's command line flags.
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
There is a need for a standard library of APIs for JavaScript runtimes, as there are currently multiple ways to perform fundamental tasks like base64 encoding. JavaScript runtimes have historically lacked a standard library, causing friction and difficulty for developers. The idea of a small core has both benefits and drawbacks, with some runtimes abusing it to limit innovation. There is a misalignment between Node and web browsers in terms of functionality and API standards. The proposal is to involve browser developers in conversations about API standardization and to create a common standard library for JavaScript runtimes.
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
ESM Loaders enhance module loading in Node.js by resolving URLs and reading files from the disk. Module loaders can override modules and change how they are found. Enhancing the loading phase involves loading directly from HTTP and loading TypeScript code without building it. The loader in the module URL handles URL resolution and uses fetch to fetch the source code. Loaders can be chained together to load from different sources, transform source code, and resolve URLs differently. The future of module loading enhancements is promising and simple to use.
Diagnostics de Node.js listos para usar
Node Congress 2022Node Congress 2022
34 min
Diagnostics de Node.js listos para usar
This talk covers various techniques for getting diagnostics information out of Node.js, including debugging with environment variables, handling warnings and deprecations, tracing uncaught exceptions and process exit, using the v8 inspector and dev tools, and generating diagnostic reports. The speaker also mentions areas for improvement in Node.js diagnostics and provides resources for learning and contributing. Additionally, the responsibilities of the Technical Steering Committee in the TS community are discussed.
Compatibilidad con Node.js en Deno
Node Congress 2022Node Congress 2022
34 min
Compatibilidad con Node.js en Deno
Deno aims to provide Node.js compatibility to make migration smoother and easier. While Deno can run apps and libraries offered for Node.js, not all are supported yet. There are trade-offs to consider, such as incompatible APIs and a less ideal developer experience. Deno is working on improving compatibility and the transition process. Efforts include porting Node.js modules, exploring a superset approach, and transparent package installation from npm.