Redis Database FAQ
Redis is single-threaded and only one command is executed at a time. Commands can only be executed one by one
1. Why is Redis single thread so fast?
- Pure memory, essentially data in memory, very fast
- Non-blocking IO
- Avoid thread switching and race consumption
2. What are the data types of Redis?
-
String: not only can be a String, but also can be an integer, floating point number type – common usage scenarios:
- Cache: Used as a cache for various kinds of information
- Counters: A natural fit for counters because they are single-threaded, so there is no error when counting increases during concurrent execution
- A distributed lock
-
List: A linked List in which each node contains a string
- Bidirectional linked list implementation
- It can be repeated, inserted at both ends, and ordered
- Common usage scenarios: Concern list and message list
-
Hash: Mapping table of field and value of String type
- Suitable for storing objects
- Common usage scenario: Shopping cart
-
Set the Set:
- Unordered, no repeating elements
- Provides an interface to determine whether an element is in a set, based on set can achieve union, intersection, difference set
- Common usage scenarios: common following, common fans and other functions
-
Sorted set: an ordered set
-
Compared with set, Zset adds a weight parameter score, so that the elements in the set can be arranged in order according to score
-
Common usage scenarios: leaderboards
-
3.Sorted set low-level implementation
Skip list: Based on multi-pointer ordered linked list implementation compared with red black tree advantages:
- Insertion speed is very fast because no rotation operation is required to maintain balance
- Better to realize
- Lockless operation is supported
4. What is consistent hash in Redis? What problem is it to solve?
When using a Redis cluster, servers will be hashed, that is, the number of servers will be modelled to hash. The problem with this approach is that when the number of servers changes, the location of all the caches will change
Consistent Hash algorithm: The consistent Hash algorithm also modulates, not the number of servers, but 2^32
In simple terms, a consistent Hash algorithm forms the Hash space into a virtual Hash ring. The entire space is organized clockwise, starting at 0 and ending at 2^32-1. Each server is then hashed to determine its position on the ring. The same function is used to hash out the position on the ring, and from that position, the first server encountered clockwise is where the data is stored. This way, when the number of servers increases or decreases, less data is affected. For example, when a new server is added, only the data between this new server and its previous server (counterclockwise previous server) will be affected, and other data will not be affected. When a server fails, the data affected is only between that server and the previous one
5. The difference between Redis and Memcached?
Both are non-relational memory key-value databases with the following major differences:
- Data types: Memcached supports only string types, whereas Redis supports five data types
- Data persistence: Memcached does not support persistence. Redis has two persistence methods: RDB snapshot and AOF log
- Distributed: Memcached does not support distributed
- Memory management mechanism:
- In Redis, not all data is stored in memory at all times. Some data that has not been used for a long time is stored on swap disks. Memcached data is stored in memory at all times
- Memcached has a low memory usage. It splits the memory into chunks of a specific length to store data, but this can cause memory underutilization
6.Redis persistence mechanism?
Redis can be persisted in two ways: RDB and AOF
- Redis DataBase snapshot: In the snapshot mode, Redis can create a snapshot to obtain a copy of the data stored in memory at a certain point in time. After creating a snapshot, Redis can back up the snapshot, copy the snapshot to another server to create a copy of the same data, or restart the server to restore the data. RDB is the default Redis persistence mode
- AOF(append-only File) : AOF persistence writes the executed write command to the end of the AOF File to record data changes
7. What are the features of transactions and what does Redis transaction implement?
ACID, ACID, ACID, ACID
In Redis, transactions are always atomic, consistent and isolated, and when Redis runs in a particular mode (with persistence enabled), transactions are persistent
8. What are cache penetration and cache avalanche? What are the solutions?
Cache avalanche: A massive failure of the cache at the same time, causing the database to collapse under the weight of requests in a short period of time
Cache penetration: Hackers deliberately request data that does not exist in the cache, causing all requests to fall on the database, causing the database to collapse under a large number of requests in a short period of time
Caching avalanche solutions:
- Pre-event: try to ensure the high availability of the entire Redis cluster and make up for machine outages as soon as possible. Choose an appropriate memory elimination strategy
- In: Local EhCache + Hystrix limit and degrade to avoid MySql crash
- After the fact: Recover cache as soon as possible using redis persistence mechanism
Cache penetration solutions:
- Bloom filter: Hash all possible data into a bitmap large enough that a non-existent data will be intercepted by the bitmap, thus avoiding the query pressure on the underlying storage system
- If a query returns a null result, the null result is still cached, but the expiration time is set very short, no more than 5 minutes
9. How does Redis set the expiration time
Expire key seconds, for example:
Expire xiaoming 30 set the expiration time of the xiaoming key to 30 seconds. You can use the TTL key to check the remaining lifetime of the key
TTL xiaoming 19, the remaining lifetime of the xiaoming key is 19 seconds
- Expire key TTL seconds: sets the expiration time to TTL seconds
- Pexpire key TTL milliseconds, which sets the expiration time to TTL milliseconds
- Expireat key TTL timestamp: Sets the expiration time to the number of seconds represented by TTL
- Pexpireat key TTL timestamp, set the expiration time to the millisecond timestamp represented by TTL
10. How to ensure that the cache and database double write are consistent
-
If the cache expiration time is set, all write operations are performed on the database. If the cache expiration time is reached, subsequent database read operations will automatically read new values to backfill the cache
-
Update the database, then delete the Cache. If there is no data in the Cache, then update the Cache. Update the database before deleting the cache.
Asynchronous update caching (subscription binlog-based synchronization) can be used:
- Once a write, delete, or update occurs in mysql, you can push binlog-related messages to Redis, which then updates Redis based on the records in the binlog
11.Redis memory elimination mechanism
When redis memory exceeds maxMemory, redis memory flushing is required. The main strategies are as follows:
- Volatile – lRU: Eliminates the most recent and oldest unused data from a data set that has been set to expire
- Volatile – TTL: Eliminates expiring data from a set with an expiration time
- Volatile -random: Selects any data from a set whose expiration time has been set for elimination
- Allkeys-lru: Removes the most recent unused data from the dataset
- Allkeys-random: Selects any data from the dataset for elimination
- Noeviction: Won’t eliminate data, bugs will be generated when memory is out of order