A list of frequently asked Redis Interview Questions and answers are given below.
1) What is Redis?
Redis is an open-source, advance key value data store and cache. It is also referred as a data structure server which keys not only contains strings, but also hashes, sets, lists, and sorted sets.
2) What is the meaning of Redis?
Redis stands for REmote DIctionary Server.
3) How is Redis different from other databases?
Redis is a NoSQL, Opensource, in-memory data-structure store. It follows the principle of key-value store.
4) In which language Redis is written?
Redis is written in ANSI C and mostly used for cache solution and session management. It creates unique keys for store values.
5) What is the usage of Redis?
Redis is a special key-value store database that can function as a NoSQL database or as a memory-cache store to improve performance when serving data that is stored in system memory.
6) How to interect with Redis?
After the installation of the server you can run the Redis Client provided by redis installation or you can open the command prompt and use the following command:
By using any of them, you can interect with Redis.
7) Which are the most popular companies using Redis?
Twitter, Github, Stackoverflow etc. are the most popular companies using Redis.
8) What are the main features of Redis?
Following are the main features of Redis:
Redis is very simple to install setup and manage.
Redis is very fast. It can execute 100000 queries per second.
Redis is fast because data is being persistent in memory as well as stored on the disk.
Redis is very fast because it loads the whole dataset in primary memory.
Redis operations working on different data types are atomic so these operations can be accomplished safely i.e. to set or increase a key, add or remove elements from a set or increase a counter.
It supports various types of data structure such as strings, hashes, sets, lists, sorted sets etc.
Redis supports a variety of languages i.e. C, C++, C#, Ruby, Python, Twisted Python, PHP, Erlang, Tcl, Perl, Lua, Java, Scala etc.
If your favorite language is not supported yet, you can write your own client library, as the Protocol is pretty simple.
Redis supports simple master to slave replication.
Redis is portable.
9) Explain the Replication Features of Redis?
Replication is important in order to archive high level of availability in big data systems. The data needs to be replicated at n number of places. This follows the master-slave approach where the master copy is maintained by master-slave and replicated to n other nodes.
10) What are the advantages of using Redis?
Following is a list of some important advantages of Redis:
Redis is very fast.
It supports a server-side locking.
It has a rich client side library.
It is a good counter.
It supports Atomic Operation.
11) What are the disadvantages/limitations of using Redis?
Following are the disadvantages/ limitations of Redis:
It is single threaded.
It has got limited client support for consistent hashing.
It has significant overhead for persistence.
It is not deployed widely.
12) What is the difference between Redis and RDBMS?
There are a lot of differences between Redis and RDBMS:
Redis is a NoSQL database while RDBMS is an SQL database.
Redis follows the key-value structure while RDBMS follows the table structure.
Redis extremely fast while RDBMS is comparatively slow.
Redis stores all the dataset in primary memory while RDBMS stores its dataset in secondary memory.
Redis is generally used to store small and frequently used files while RDBMS is used to store big files.
Redis provides only official support for Linux, BSD, Mac OS X, Solaris. It doesn?t provide official support for Windows currently while RDBMS provides support for both.
13) Differentiate Memcached and Redis?
Memcached only does caching information.
Memcached supports the functionality of LRU (Least Recently Used) eviction of values.
In Memcached, when they overflow memory, the one you have not used recently (LRU- Least Recently Used) will get deleted.
CAS (Check and Set) is supported by Memcached.
Array objects are needed to be serialized in order to get saved. We need to unserialize them for their retrieval.
Memcached has at most 250 bytes length.
It is Multi-threaded
It provides some more functionalities like replication and persistence along with caching information.
LRU is not supported by Redis.
In Redis, there is a time set for each function, Three keys are maintained, the one, which is closest to expiry, will get deleted.
CAS is not supported by Redis.
Redis has got stronger data structures; it can handle strings, binary safe strings, list of binary safe strings, sorted lists, etc.
Redis has at most 2 GB key length.
It is single threaded.
14) Mention Operation Keys of Redis.
EXPIRE key seconds
EXPIREAT key timestamp
15) Which are the different data types used in Redis?
There are mainly 5 types of data types supported by Redis:
16) Which are the most popular commands of the Redis database?
APPEND key value: Append a value to a key
AUTH password: Authenticate to the server
CLIENT LIST: Get the list of client connections
CLIENT GETNAME: Get the current connection name
CLIENT PAUSE: timeout Stop processing commands from clients for some time
CLUSTER COUNTKEYSINSLOT: slot Return the number of local keys in the specified hash slot
CLUSTER FORGET: node-id Remove a node from the nodes table
CLUSTER GETKEYSINSLOT: slot count Return local key names in the specified hash slot
CLUSTER INFO: Provides info about Redis Cluster node state
CLUSTER KEYSLOT: key Returns the hash slot of the specified key
CLUSTER MEET: ip port Force a node cluster to handshake with another node
CLUSTER NODES: Get Cluster config for the node
CLUSTER REPLICATE: node-id Reconfigure a node as a slave of the specified master node
CLUSTER RESET [HARD|SOFT]: Reset a Redis Cluster node
CLUSTER SAVECONFIG: Forces the node to save cluster state on disk
CLUSTER SET-CONFIG-EPOCH: config-epoch Set the configuration epoch in a new node
CLUSTER SLAVES: node-id List slave nodes of the specified master node
CLUSTER SLOTS: Get array of Cluster slot to node mappings
COMMAND: Get array of Redis command details
COMMAND COUNT: Get total number of Redis commands
COMMAND GETKEYS: Extract keys given a full Redis command
CONFIG GET: parameter Get the value of a configuration parameter
CONFIG REWRITE: Rewrite the configuration file with the in memory configuration
CONFIG SET: parameter value Set a configuration parameter to the given value
CONFIG RESETSTAT: Reset the stats returned by INFO
DBSIZE: Return the number of keys in the selected database
DEBUG OBJECT: key Get debugging information about a key
DEBUG SEGFAULT: Make the server crash
DECR key: Decrement the integer value of a key by one
DECRBY key: decrement Decrement the integer value of a key by the given number
DEL key: [key …] Delete a key
DISCARD: Discard all commands issued after MULTI
DUMP key: Return a serialized version of the value stored at the specified key.
ECHO: message Echo the given string
17) We all know that Reds is fast, but is it also durable?
In Redis, there is always a trade-of between durability and speed. In the case of system failure, it may lose data which is not stored.
18) How can you enhance the durability of Redis?
Whenever a new command is added to the append log file, call Fsysnc() each time.
Keep calling Fsysnc() in every second. Despite of the 1 second data lose in the case of system fails.
19) What are the concerned things while using Redis?
Consistent method selection in order to name and prefix the keys. Namespace management.
Make key prefixes registry which can map every documents to their owner applications.
Designing, implementing and testing the Garbage collection mechanism for each class we keep into the redis architecture.
Maintain a sharding library before investing so much into the application.
20) How can you use Redis with .Net application?
To use Redis in .Net applications, follow these steps:
First, Download Redis Server.
Install Redis Server.
Download Redis Client.
Set Configuration into Web.config File.
Use Redis Client Class.
For more Interview Questions And Answers click here