What can be gained by reading this article
1. What is optimism lock? 2. What are the implementation methods of optimistic lock? 3. What are the advantages and disadvantages of optimistic lock? 4, optimistic lock applicable scenarios? 5. What is pessimism lock? 6, what are the pessimistic lock implementation methods? 7, advantages and disadvantages of pessimistic lock? 8, pessimistic lock applicable scenarios?Copy the code
First of all, let’s take A look at what optimistic lock is. In my personal understanding, optimistic lock can be abstracted as going to the bank to withdraw money. If there is no queue in the bank, there is no need to take the number, so you can directly go to counter A to handle business. Conversely pessimistic lock is if go to A bank to take money, go every time very coincidentally of uncoincidentally somebody is queuing up in bar A, need to take number right now so, wait for call number to deal with business in bar A next. (Suppose the bank only has one counter A, not very visual, just to show the problem, optimistic lock everything is optimistic, pessimistic lock is pessimistic), let me look at the standard explanation how to say, first let’s look at what is optimistic lock?
Optimistic locking
- Optimistic Locking mechanism adopts a looser Locking mechanism compared with pessimistic Locking. Pessimistic locking is mostly implemented by the locking mechanism of the database to ensure maximum exclusivity of operations. However, the resulting database performance costs, especially for long transactions, are often prohibitive. Optimistic locking mechanism solves this problem to a certain extent. Optimistic locking is mostly implemented based on the data version recording mechanism. What is data version? This is to add a version id to the data, typically by adding one to the database table in a database table-based version solution
version
Field to implement. When the data is read, the version number is read together, and when it is updated later, the version number is added by one. In this case, the version of the submitted data is compared with the current version of the database table. If the version of the submitted data is equal to the current version of the database table, the data is updated. Otherwise, the data is considered to be expired.
Optimistic locking is an optimistic locking mechanism that can be implemented based on the version field. If you are smart enough, you must have already thought of CAS. Compare and swap (CAS) Compares and changes the CAS. The CAS requires three parameters: memory address V, the old expected value A, and the new value B. The value of V is changed to B only when V is equal to A.
Ok, so we know that there are version number mechanism and CAS mechanism for optimistic lock implementation, so what are the problems caused by these two mechanisms? Follow me to find out
What is the ABA problem? The ABA problem is that Zhang SAN left 100 yuan on the table, li Si used 100 yuan in the middle, and then put another 100 yuan on the table. When Zhang SAN returned, he found that the 100 yuan was still 100 yuan, so he thought it was still his 100 yuan. This is the classic ABA problem. Add the version number (the version number must be in ascending order), determine the version, only if the version number is the same, then change the value of the version number +1; If the version number does not match when updating the value, the change will not be made, thus avoiding THE ABA problem
However, the CAS spin will keep trying to acquire the lock. If the lock cannot be acquired, the CPU will burst the table, causing a lot of overhead. So in summary, optimistic locking is better for scenarios where there is a lot of reading and a lot of writing, so that conflicts really don’t occur, which reduces the cost of locking. However, if there are frequent conflicts and the application is constantly trying to lock, the system performance will be affected, so pessimistic locking is better than pessimistic locking
Pessimistic locking
Pessimistic locks and what is, in fact, watching the optimistic locking, the concept of pessimistic locking themselves should also have A certain concept, yes, you think that’s right, pessimistic locking is very pessimistic, no matter do what, assume is conflict scenario, with the example of words which we went to the bank to withdraw money is to go and get some money every time there are A lot of people in the counter A withdraw money, were standing in line waiting for, When it was my turn to withdraw money, everyone else had to wait, too. Corresponding to our scenario is that no matter who to obtain resources, must first get the lock, which is also a popular point to talk about the concept of pessimistic lock, or according to the convention to look at the orthodox statement:
- Pessimistic locks, as the name suggests, are intensely exclusive and exclusive. It refers to the conservative attitude towards data being modified by other transactions, including the current transactions of the system, as well as transactions from external systems, and therefore keeping the data locked throughout the data processing process. The realization of pessimistic lock, often rely on the locking mechanism provided by the database (only the locking mechanism provided by the database layer can truly ensure the exclusivity of data access, otherwise, even if the locking mechanism is implemented in this system, it can not guarantee that the external system will not modify the data).
So, in this case, what are the advantages and disadvantages of pessimistic lock? First, the advantage is to ensure sequential read and write in multiple threads and prevent the generation of dirty data. The disadvantage is that the performance of concurrent scenarios is significantly reduced.
Therefore, pessimistic locking is suitable for scenarios with less read and more write. In this scenario, there are more conflicts, so pessimistic locking is suitable. At present, I know the pessimistic Lock implementation methods are Lock and Synchronized, followed by MySQL for update statement, MySQL query statement, select…… For update is an exclusive lock on data, which is also a pessimistic lock. So our access to the data locks the data, and subsequent operations on the data queue up until we get the lock
In addition to the MySql query statements use pessimistic locks, there are a lot of places with the optimistic locking in pessimistic locking, for example, Java. Util. Concurrent. The Atomic variable is the use of CAS mechanism of Atomic, Elasticsearch is to use the version of optimistic locking mechanism
conclusion
Optimistic locking can be implemented in the Version (sequential increment) Version mechanism and CAS mechanism. Pessimistic Lock implementation methods include Synchronized and Lock, database for update pat it Lock. Optimistic locks are suitable for read and write scenarios, while pessimistic locks are suitable for read and write scenarios
This is the end of this article, a brief overview of the concept of optimistic locking and pessimistic locking, if not correct, welcome to progress together
[url = mp.weixin.qq.com/s?__biz=MzI]