La conexión a una base de datos es uno de los aspectos fundamentales de la programación back-end, pues nos permite guardar toda la información relevante para la página web de manera física. Sin embargo, debido a que es un método de almacenamiento secundario (en disco), conforme crece la base de datos, las llamadas realizadas por nuestro servidor tienden a volverse más lentas.
En una computadora, se sabe que la memoria principal o la caché aumentan de manera significativa la velocidad con la que se procesa la información en comparación con el almacenamiento secundario. En el caso del desarrollo web, se creó una herramienta que pudiera otorgar una funcionalidad similar para aumentar el rendimiento de las páginas web: REDIS.
¿Qué es REDIS?
Básicamente, REDIS es una herramienta de estructuras de datos en memoria, utilizada como caché de una base de datos. Con ella, la mayoría de los datos se encuentran en memoria, haciendo que la búsqueda de información requerida a través de queries sea mucho más rápida. No todas las funcionalidades (como llaves foráneas, por ejemplo) vienen incluídas, pero se obtiene rapidez.
REDIS ofrece, entonces, persistencia de datos.
¿Cómo funciona?
Manejando estructuras de datos de tipo:
- Listas
- Tablas de dispersión
- Cadenas
- Conjuntos (tanto ordenados como no ordenados)
El programador puede almacenar los resultados obtenidos a través de las queries a la base de datos y acceder a ellas de manera simple y rápida. De manera remota, REDIS guarda la información requerida, por ejemplo, una consulta de un artículo puede almacenarse en una tabla de dispersión utilizando como llave su código o algún otro atributo. Todo esto tiende a ser útil en datos que son constantemente necesarios obtener de la base de datos.
Sin embargo, como pasa en la memoria principal y secundaria de una computadora, la memoria principal tiene mayor velocidad, pero con la diferencia de que su capacidad de almacenamiento es mucho menor que la de un disco. En este caso, es obvio que no toda la información de una base de datos puede ser almacenada en las estructuras ofrecidas por REDIS; por lo que se tiene que definir una manera de dar prioridad a la información que se va a quedar almacenada y cuál va a ser borrada para dar lugar a los nuevos datos que se requieren tener guardados.
Para ello, REDIS utiliza un algoritmo de caché llamado Least Recently Used (LRU), el cual básicamente va eliminando los datos que han sido utilizados de manera menos reciente, pues ello significa que el programa no accede a ellos de manera regular comparado con otra información.
Ejemplos
REDIS es soportado en una gran variedad de lenguajes, pero para fines de ilustración de funcionamiento básico, vamos a ver cómo trabaja en PHP.
Predis es un cliente de REDIS para PHP, para lo cual es necesario descargarlo para poder utilizarlo. En nuestro código de PHP simplemente definimos la variable:
1 |
$redis = new PredisClient(); |
Para poder trabajar con el almacenamiento y las herramientas que nos proporciona REDIS.
Listas
Trabajar con listas en REDIS es muy similar como pasa en el caso de los lenguajes de programación, como se puede observar a continuación:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
// Agrega al final de la lista $redis->rpush("materias", "programacion"); // Agrega al inicio de la lista $redis->lpush("materias", "algoritmia"); // Elimina el primer elemento de la lista $redis->lpop("materias"); // Elimina el último elemento de la lista $redis->rpop("materias"); // Regresa la longitud de la lista $redis->llen("materias"); // Regresa los elementos del rango 0 al 5 $redis->lrange("materias", 0, 5); // Regresa todos los elementos $redis->lrange("materias", 0, -1); |
Tablas de dispersión
Para las tablas de dispersión es un uso similar, solo que ahora se hace uso de llaves para acceder a la información necesaria.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
$llave = 'alumno_2142'; // Definir los atributos de la llave en particular $redis->hset($llave, 'edad', 20); $redis->hset($llave, 'carrera', 'ing. en computacion'); $redis->hset($llave, 'promedio', 90); $redis->hset($llave, 'correo', 'alumno@universidad.com'); // También se pueden definir de manera grupal $redis->hmset($llave, [ 'edad' => 20, 'carrera' => 'ing. en computacion', 'promedio' => 90, 'correo' => 'alumno@universidad.com', ]); // Obtener un atributo en particular $redis->get($llave, 'carrera'); // Obtener todos los datos asociados a una llave $datos = $redis->hgetall($llave); // Eliminar un atributo en particular $redis->del($llave, 'correo'); |
Referencia:
- Documentación de REDIS: https://redis.io/documentation