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
Proyecto
- 3

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

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

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

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

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

Diagrama entidad relación: usuario y post
01:41 min - 9

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

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

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

Implementar controlador Posts con TDD
10:34 min - 13

Pruebas TDD para crear y actualizar posts
10:12 min - 14

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

Active Model serializers: control total de JSON en Rails
06:03 min - 16

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

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

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

Identificación y solución del problema N+1 en Rails
Viendo ahora - 20

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

Tests con RSpec para autenticación de tokens
12:17 min - 22

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

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

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

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

Probando API Ruby on Rails con Postman
10:43 min - 27

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

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

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

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

Envío de Correos en Rails con ActionMailer y Background Jobs
11:06 min - 32
Autenticación y Autorización con JWT y Auth0 en Aplicaciones Web
03:48 min
Cierre
Resolver el N+1 query problem en Rails es clave para mejorar rendimiento sin cambiar el comportamiento. Aquí verás cómo diagnosticar con RSpec, leer los logs en pruebas y aplicar la solución más simple usando includes en el controlador. Todo con pasos claros y verificables.
¿Cómo identificar el n más uno query problem con RSpec y logs?
Para confirmar el problema, se ejecuta una sola prueba y se monitorean los logs del entorno de test. Así observas si hay múltiples SELECT repetidos en la tabla relacionada, señal inequívoca del N+1.
¿Cómo ejecutar una sola prueba con RSpec?
- Ubicar la línea de la prueba: línea 29.
- Obtener el path de la prueba: spec/requests/posts.
- Ejecutar en la terminal:
bundle exec rspec spec/requests/posts:29. - Verificar que solo corre esa prueba.
¿Cómo monitorear los logs en logs/test.rb con tail -f?
- Ir a la carpeta de logs y abrir el archivo de pruebas: logs/test.rb.
- Limpiar el archivo para empezar desde cero.
- Si se borró, recrearlo y luego correr:
tail -f logs/test.rb. - En otra terminal, repetir
bundle exec rspec spec/requests/posts:29. - Observar en el log: primero un SELECT de los posts publicados y luego múltiples
SELECT users *repetidos varias veces. Eso confirma el N+1.
¿Cuál es la solución simple con includes en el controlador de posts?
La forma más directa es usar includes para precargar la relación. Rails hace un solo query para la colección relacionada, evitando los múltiples SELECT por cada fila.
# posts_controller.rb
class PostsController < ApplicationController
def index
@posts = Post.includes(:user)
end
end
- Se incluye el modelo relacionado:
:user. - Rails extrae los IDs de usuarios de los posts y hace un solo query para traerlos.
- No cambia el comportamiento de la respuesta ni rompe pruebas.
¿Qué cambia en los logs tras aplicar includes?
- Antes: un SELECT de posts publicados + diez SELECT a users (11 queries).
- Después: dos queries totales, uno para posts y uno para todos los usuarios relacionados.
- Impacto estimado: si cada query cuesta 100 ms, pasar de 11 a 2 ahorra ~1 segundo.
¿Qué habilidades y conceptos clave se aplican?
Dominar estos puntos acelera el diagnóstico y la solución en proyectos Rails.
- N más uno query problem: múltiples queries a la tabla relacionada por cada fila de la colección. Degrada el rendimiento.
- Ejecución focalizada con RSpec:
bundle exec rspec spec/requests/posts:29reduce el tiempo de análisis. - Lectura de logs en pruebas: uso de logs/test.rb para ver los SELECT ejecutados.
- Monitoreo en tiempo real:
tail -fpara observar cómo se disparan los queries. - Verificación del patrón: un SELECT de posts publicados seguido de muchos
SELECT users *indica N+1. - includes en Rails: precarga de asociaciones para convertir muchos queries en uno solo por relación.
- Controlador de posts: aplicar
Post.includes(:user)al construir la colección. - Métrica práctica: de 11 queries a 2, con ahorro notable de tiempo por petición.
¿Te pasó algo similar con otras asociaciones? Cuéntalo y comparte qué mejoras viste en tus logs al aplicar includes.