Aceleración de Búsquedas en Rails con Caching
Clase 28 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
06:20 min - 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
Viendo ahora - 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
Optimiza el rendimiento de tu API en segundos: aprende a usar el caching de Rails para acelerar búsquedas de posts, reducir carga en la base de datos y mantener una experiencia rápida sin sacrificar mantenibilidad. Con una clave de cache bien definida, un expires_in razonable y consultas por IDs indexados, los tiempos de respuesta mejoran notablemente.
¿Por qué usar cache en búsquedas de posts en Rails?
Cuando se buscan títulos con SQL usando un patrón con LIKE, el desempeño cae en colecciones grandes. Las bases de datos relacionales no están optimizadas para búsqueda de texto libre, por lo que pueden volverse lentas con miles o millones de registros. Con caching vía Rails.cache.fetch, guardas resultados y evitas recalcular en cada solicitud.
- Las búsquedas con LIKE no usan índices eficientemente y son lentas en grandes volúmenes.
- El cache funciona como almacén llave-valor: si existe, retorna; si no, calcula y guarda.
- Usa
expires_inpara evitar resultados obsoletos y controlar frescura. - Se prioriza desempeño sobre correctitud: es un trade off explícito.
¿Qué limita a las bases de datos SQL con texto?
- Patrones con LIKE escanean muchas filas.
- No están diseñadas para búsqueda full-text por defecto.
- En producción, el costo crece con el tamaño de los datos.
¿Qué implica el trade off entre correctitud y desempeño?
- Guardar resultados por una hora acelera respuestas.
- Durante ese periodo, nuevos posts que coincidan podrían no aparecer.
- Es un intercambio intencional y común en sistemas reales.
¿Cómo implementar Rails.cache.fetch con clave y expiración?
La idea central: cachear solo lo necesario (IDs) y luego consultar por IDs ya indexados. Así reemplazas un query costoso por uno rápido.
# Ejemplo de implementación del servicio de búsqueda
# 1) Cachea los IDs que matchean el título con LIKE.
ids = Rails.cache.fetch("post_search:#{query}", expires_in: 1.hour) do
Post.where("title LIKE ?", "%#{query}%").pluck(:id)
end
# 2) Recupera los registros por ID (consulta rápida e indexada).
posts = Post.where(id: ids)
Rails.cache.fetch: accede al cache y calcula bajo demanda.- Clave sugerida:
post_search:#{query}para agrupar por término buscado. expires_in: 1.hour: evita stale data permanente y controla frescura.pluck(:id): ahorra espacio en cache guardando solo IDs.
¿Cómo definir la clave y qué guardar?
- Incluye el término de búsqueda en la clave.
- Guarda la menor cantidad de datos posible: solo IDs.
- Evita almacenar objetos completos para no agotar memoria del cache.
¿Cómo consultar por IDs luego del cache?
- Usa
where(id: ids)para aprovechar índices por ID. - El primer acceso hace el LIKE; los siguientes reutilizan el resultado.
- En pruebas manuales: la segunda búsqueda debe mostrar solo el query por IDs.
¿Qué opciones de cache convienen en desarrollo y producción?
Rails ofrece varias estrategias de cache. En desarrollo suele usarse memory store; en producción se recomienda un cache distribuido como memcache o Redis para entornos con múltiples nodos.
- Desarrollo:
:memory_storeguarda en memoria del proceso. - Producción: prefiere memcache o Redis para compartir entre nodos.
- Configuración en archivos de environment (
development,production,test).
¿Cómo configurar memory store, memcache o Redis?
En config/environments/production.rb (o el entorno que uses):
# Memory store con tamaño límite
config.cache_store = :memory_store, { size: 64.megabytes }
config.action_controller.perform_caching = true
Para memcache o Redis, ajusta :cache_store según tu infraestructura y variables de entorno.
¿Cómo validar con pruebas y consola?
- Ejecuta el suite de pruebas para asegurar que la búsqueda no cambió su contrato.
- En consola de Rails:
- Primera búsqueda: se ve el query con LIKE y luego por IDs.
- Segunda búsqueda: solo el query por IDs, señal de cache hit.
¿Tienes dudas sobre la clave, la expiración o la elección de store? Cuéntame tu contexto y deja un comentario para explorar alternativas y mejoras.