“I have not failed. I’ve just found 10,000 ways that won’t work.” – Thomas Edison
- Redis is an in-memory database
- Redis stands for Remote Dictionary Server
- It uses key-value pair storage (JSON)
- It can be used as primary database and also cache
- It runs on RAM so the speed of fetching and reading data is very fast (50X faster than other DB that runs in hard disk)
1. As Redis is stores data in RAM, it delivers sub-millisecond response times enabling millions of requests per second
2. That is why many real-time applications are implemented on top of the Redis.
1. It offers single node and multi cluster topology
2. Redis is single-threaded, so uses one thread uses I/O ops
3. It uses master slave architecture
4. It can be scaled horizontally and also vertically
1. As Redis is in-memory storage, it uses backup technique to store the data in hard-disk to use it in future if node is failed
2. It use RDB & AOF backup mechanism
RDB (Redis Backup):
- Performs point-in-time snapshots of data at specified interval
- This is not recommended as we dont have some part of persisted data when node failed as we store till last snapshots
AOF (Append Only File):
- This will append all the write operations of the redis server
- This is recommended as we store all the operations and no data is lost
- Redis is helpful as we can store different type of data in key-value pairs
- Its not associated with the technology limitations
Data structures:
1. String
2. Hash
3. List
4. Set
5. Sorted Set
6. Bitmaps
7. Streams
8. Documents
-
Caching:
- Caching is storing data for temporary period (non-volatile). As Redis is in-memory storage, data persist till RAM is in use
- It faster to fetch and write data in RAM
- Web browser engine uses cache to load website faster by fetching domain from cache rather than fetching details from central server
-
Messaging:
- It can be used in messaging/ chat application
- It can be used to store last 10 messages using Redis LIST
- Some of the user details be hashed and can be used in in-memory till chat longs in system
- Redis can be used in Mac and linux by downloading redis from cmd prompt
- In Windows, we need to install redis from WSL
- Alternatively we can use cloud Redis using RedisLabs or Upstash
- Nodejs (ioredis/ redis)
- Python (redis)
- Java (jedis)
- Packages used:
- express
- ioredis
- redis
- Clone this package.json and run cmd "npm install" to install above packages
- For cloud Redis use below links Upstash, RedisLabs
- For localhost Redis download and install Redis and Redis cli
- In server.js use below code to connect to redis (localhost/ cloud)
import express from "express";
import redis from "redis";
import redis from "redis";
const client = redis.createClient({
host: <HOSTNAME>,
port: <PORT>,
password: <PWD>,
});
await client.connect();
client.on("connect", () => {
console.log("connected");
});
client.set("foo", "bar");
const value = client.get("foo);