Identificación y solución del problema N+1 en Rails
Clase 19 de 33 • Curso de Creación de APIs con Ruby on Rails
Contenido del curso
- 3

Creación de APIs con Rails: Proyecto Blog API paso a paso
04:37 - 4

Configuración de Gemas para Pruebas en Proyectos Rails
06:26 - 5

Configuración de Gemas en Proyectos Rails: Arspec, Factory Bot y Database Cleaner
07:25 - 6

Implementación de un Health Check Endpoint en API con RSpec
12:28 - 7

Diseño de Casos de Uso y Diagramas de Entidad para Aplicaciones
03:16 - 8

Diagrama de Entidad Relación para Modelos de Aplicación
01:41 - 9

Modelado de Aplicaciones con TDD en Rails
05:59 - 10

Validaciones y Pruebas TDD en Rails: Modelos USR y Post
07:07 - 11

Implementación de Endpoints para Listar y Mostrar Posts con TDD
15:12 - 12

Implementación de Pruebas y Controladores en Rails
10:34 - 13

Creación y Actualización de Posts con Pruebas TDD
10:12 - 14

Implementación de Métodos y Manejo de Excepciones en Rails API
10:23 - 15

Serialización de Modelos en Rails con ActiveModelSerializer
06:03 - 16

Búsqueda y Filtrado de Posts por Título con TDD
05:57 - 17

Implementación de Búsqueda de Posts con Servicios en Rails
06:06 - 18

Problema N+1 en Rails: Detección y Solución Eficaz
04:40 - 19

Identificación y solución del problema N+1 en Rails
06:20 - 20

Flujo de Autenticación en APIs con Tokens y Proveedores
05:29 - 21

Pruebas de Autenticación en API con Test Driven Development
12:17 - 22

Autenticación con Tokens: Implementación en Rails API
05:54 - 23

Autenticación de Usuarios en Controladores Rails
09:20 - 24

Autenticación y Seguridad en CRUD de Posts en Rails
09:17 - 25

Pruebas de Creación y Actualización con Autenticación en Rails
14:21 - 26

Pruebas de API con Postman: Ejecución y Verificación de Respuestas
10:43 - 27

Caching en Aplicaciones Web: Funciones y Niveles
07:15 - 28

Aceleración de Búsquedas en Rails con Caching
08:23 - 29

Background Jobs en Rails: Conceptos y Funcionalidades
05:45 - 30

Procesamiento en Background y Envío de Correos con Rails
09:45 - 31

Envío de Correos en Rails con ActionMailer y Background Jobs
11:06 - 32
Autenticación y Autorización con JWT y Auth0 en Aplicaciones Web
03:48
¿Cómo identificar el problema N+1 Query en nuestras aplicaciones?
¡Abordemos uno de los desafíos más frustrantes en el desarrollo web! El problema del N+1 Query afecta el rendimiento de base de datos de muchas aplicaciones y puede ralentizarla considerablemente. Pero no te preocupes, aquí te vamos a enseñar cómo identificarlo y resolverlo usando Rails y Arspec.
Para detectar el problema vamos a utilizar pruebas específicas en nuestras aplicaciones. Observemos el test en el que listamos nuestros posts ya que es allí donde se manifiesta el problema. En Rails, podemos usar una funcionalidad de Arspec para ejecutar únicamente una prueba específica en vez de todo el conjunto de pruebas. Para esto:
- Ubica la línea donde está la prueba en tu archivo (por ejemplo, la línea 29).
- Ejecuta el comando en la terminal con:
bundle exec rspec path/a/tu/prueba:numero_de_linea - Observa los logs generados en modo de pruebas para identificar consultas innecesarias.
¿Cómo monitorear los logs de prueba?
Monitorear los logs es crucial para diagnosticar el problema N+1. Aquí te mostramos cómo hacerlo:
- Accede al archivo
logs/test.logdentro de tu proyecto para observar las acciones que se ejecutan en el entorno de pruebas. - Limpia el log para comenzar con una pizarra limpia.
- Utiliza el siguiente comando en la terminal para monitorear el log en tiempo real:
tail -f logs/test.log
Corriendo la prueba en una terminal y monitoreando el log en otra, puedes ver dónde se generan los múltiples SELECTs innecesarios (por ejemplo, SELECT users * repetido varias veces), que representan el problema N+1.
¿Cómo solucionar el problema N+1 Query en Rails?
¡No es complicado! Para solucionar el problema, podemos utilizar el método includes en nuestro controlador de Rails que maneja posts. Este método permite a Rails realizar un solo query para extraer las entidades relacionadas. Aquí un ejemplo de cómo implementarlo:
# En tu controlador de posts
def index
@posts = Post.includes(:user).where(publicado: true)
end
Con este cambio:
- Rails ejecutará un solo SELECT para los posts y un solo SELECT para los usuarios relacionados, reduciendo el número de queries de once a dos.
Gracias a esta optimización, si cada query toma un promedio de 100ms, nos ahorramos alrededor de 1 segundo en total. Lo más importante, nuestras pruebas seguirán pasando, asegurándonos que no alteramos el comportamiento deseado de nuestra aplicación.
Continúa explorando formas de optimizar el rendimiento de tus aplicaciones y recuerda, ¡cada pequeña mejora cuenta!