Pessimistic and optimistic locking

Posted 许仙儿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Pessimistic and optimistic locking相关的知识,希望对你有一定的参考价值。

Transactional isolation is usually implemented by locking whatever is accessed in a transaction. There are two different approaches to transactional locking: Pessimistic locking and optimistic locking.

The disadvantage of pessimistic locking is that a resource is locked from the time it is first accessed in a transaction until the transaction is finished, making it inaccessible to other transactions during that time. If most transactions simply look at the resource and never change it, an exclusive lock may be overkill as it may cause lock contention, and optimistic locking may be a better approach. With pessimistic locking, locks are applied in a fail-safe way. In the banking application example, an account is locked as soon as it is accessed in a transaction. Attempts to use the account in other transactions while it is locked will either result in the other process being delayed until the account lock is released, or that the process transaction will be rolled back. The lock exists until the transaction has either been committed or rolled back.

With optimistic locking, a resource is not actually locked when it is first is accessed by a transaction. Instead, the state of the resource at the time when it would have been locked with the pessimistic locking approach is saved. Other transactions are able to concurrently access to the resource and the possibility of conflicting changes is possible. At commit time, when the resource is about to be updated in persistent storage, the state of the resource is read from storage again and compared to the state that was saved when the resource was first accessed in the transaction. If the two states differ, a conflicting update was made, and the transaction will be rolled back.

In the banking application example, the amount of an account is saved when the account is first accessed in a transaction. If the transaction changes the account amount, the amount is read from the store again just before the amount is about to be updated. If the amount has changed since the transaction began, the transaction will fail itself, otherwise the new amount is written to persistent storage.

 

from: https://docs.jboss.org/jbossas/docs/Server_Configuration_Guide/4/html/TransactionJTA_Overview-Pessimistic_and_optimistic_locking.html

以上是关于Pessimistic and optimistic locking的主要内容,如果未能解决你的问题,请参考以下文章

Pessimistic and Optimistic locking

JPA中的PESSIMISTIC_READ和PESSIMISTIC_WRITE有什么区别?

Hibernate JPA - PESSIMISTIC.WRITE 不工作

带有 PESSIMISTIC_WRITE 锁的 REPEATABLE_READ 隔离级别

Lockmodetype.Pessimistic_Read 正在锁定锁定行以外的行

Java 悲观锁Pessimistic-Lock常用实现场景