“This article has participated in the call for good writing activities, click to view: [back end, big front end double track submission, 20,000 yuan prize pool waiting for you to challenge!
In the daily development process, the use of Redis and MySQL must be familiar. When faced with some relatively simple usage scenarios, this doesn’t seem too difficult. But when it comes to synchronizing data between caches and databases, one careless consideration might be to prepare your resume. Today Xiao Yang will talk to you about this.
When we operate Redis, we usually use the following scenarios: (1) write less and read more, the scenario of low modification; (2) store some hot data or configuration, so as to relieve the pressure of the database. However, when caching and databases are used in more complex scenarios, data consistency becomes an issue, especially when there are many requests. Next, we will analyze some common solutions and analyze their advantages and disadvantages for you to choose from.
First of all, the cache, whether to delete or update
For caches, I think the right thing to do is delete the cache first, not update it. A more common approach is to delete the cache first, then look up the database the next time the query cache is not available, and write the results to the cache. Here’s why:
1. If there are more writes than reads, each update will waste performance, especially when the data has gone through a series of complex calculations or operations.
2. When two threads update the cache by updating the database, if network delay or lag occurs, the order of updating the cache may be different, resulting in dirty data in the cache.
Do you delete the cache and then update the database, or do you update the database and then update the cache
In the case of deleting the cache first and updating the database later, we will find data inconsistencies. Such as:
- When the first request comes in, the cache is deleted
- The second request finds that there is no cache and reads from the database and writes to the cache
- The first request writes the data to the database
Update the database first, then the cache
In this case, if the consistency problem is not very strict, you can use this approach, but in some high concurrency, there are still some problems, such as the following example:
- There was a query request before updating the database, and it happened that the cache was invalid, so the database was queried and the data was obtained
- At this point, a write request occurs, the database is updated with the new value and the cache is removed
- The first request writes the value to the cache (at this point, the data is old, i.e., data inconsistency has occurred)
Based on the above analysis: why can we still get the recommendation? The reason is that the condition of the above situation is that the query database of the first step will be slower than the write database of the second step, and the situation of deleting first and then writing will occur, which is relatively small. Most databases have a read-write separation architecture, so the read speed is faster than the write speed.
Cache delay dual-delete
This is the most recommended scheme, which is improved and optimized on the basis of the first one. The process is as follows:
-
Delete the cache first
-
Rewrite database
-
Hibernate for x seconds before deleting the cache
In order to resolve the synchronization time difference between the primary and secondary libraries during database writes, ensure that read requests end and write requests can delete cached dirty data caused by read requests. The length of this sleep depends on how long it takes the project to read the data business logic
There are some optimizations that can be made for the above delayed double deletion:
1. Asynchronously delete the cache of step 3, so that there is no need to hibernate each time, thus improving throughput and performance.
2. If you are concerned about the deletion failure, you can consider adding a retry mechanism. For example, if the test fails for three times, it can be put into the queue again and wait for the next retry.
Welcome to our discussion below. If there are any mistakes in this blog, please comment, thank you very much!
Make progress together, learn and share
If you think it’s written well, click a “like” and add a follow! Keep updating!! Pay attention, don’t get lost, Xiao Yang take you to the highway
We have sorted out hundreds of all kinds of technical e-books and learning materials, the latest interview questions, note the public number [write code xiao Yang] reply [information] no routine to receive