Modern Treasury has acquired Beam.Build for what's next →

Learn

Pessimistic Locking Vs. Optimistic Locking

Welcome to Learn, where we provide straightforward, easy-to-understand definitions of the payments industry.

Follow us

Pessimistic locking and optimistic locking are types of concurrency controls designed to handle concurrent updates in a ledger system, helping prevent race conditions and maintain immutability in financial ledgers.

Why are Concurrency Controls Important in Ledger Databases?

When several transactions take place at the same time through concurrent access, a ledger database needs a way to maintain its integrity and consistency. Concurrent access, or allowing multiple users to access a computer system or database at the same time, is common in many financial applications.

For example, consider the Starbucks app: a popular digital wallet. In the app, you’re able to manage your funds and order drinks, and the database behind the scenes maintains your balance and updates it as necessary.

All the money across everyone’s Starbucks wallet is pooled in an account. Starbucks needs to track and record which funds belong to you (versus every other person) and when you have spent them.

The balance of the pooled Starbucks account changes constantly as people order drinks, make purchases, or add money to their personal balances. This happens on a large scale, with thousands of people likely doing these things at the same time. The way they keep track of everything is with concurrency controls.

There are two types of concurrency controls: pessimistic locking and optimistic locking. These are designed to handle concurrent updates in a ledger system, prevent race conditions in databases, and maintain immutability in financial ledgers.

Transaction Isolation Levels and Multi-Version Concurrency Control (MVCC)

Before discussing pessimistic or optimistic locking, it’s important to understand a broader concept of transaction isolation levels. Transaction isolation levels are the rules that determine how transactions interact when they happen at the same time (concurrently).

Within financial ledgers, immutability—the inability to be changed or altered—is of the utmost importance. With MVCC, databases can maintain multiple versions of records, allowing for updates that affect only the most current version to reduce the potential for conflicts.

What is Pessimistic Locking?

Pessimistic locking is a concept based on the assumption that conflicts are likely to occur when multiple users or processes attempt to access and update the same resource simultaneously. With this approach, the idea is to lock first and update the information later, ensuring there are fewer conflicts.

How Does Pessimistic Locking Work?

When a transaction occurs, the database record is accessed. That’s when the record is locked. No other transaction can take place or update that record until the lock is released.

Think of this like standing in line at a store. You’re queued and ready to make a purchase, but only the first person in the line can check out. Not everyone can check out at the same time.

The Benefits and Downsides of Pessimistic Locking

Pessimistic locking has a few benefits, including:

  • Ensuring data integrity by avoiding conflicts when updating a core record
  • Granting exclusive access in a consistent manner that simplifies transaction logging

Pessimistic logging is beneficial for systems where it is common to have a few conflicting updates occurring simultaneously, but it starts to fail at scale (the queue at that store on Black Friday is a lot more overwhelming than on a Monday morning).

This has the potential for deadlocks in financial systems, which can mean reduced throughput. For the end user, this typically means a longer latency period (lag) when attempting to make a payment.

What Is Optimistic Locking?

Optimistic locking takes an alternative approach to updating databases and records. The process assumes that conflicts aren’t likely to happen and doesn’t lock resources, meaning. Transactions can take place simultaneously. This process checks for conflicts after the transactions finalize.

How Does Optimistic Locking Work?

  1. Every account has its own version number or timestamp to keep track of it.
  2. When a transaction happens, it reads the account version and records it.
  3. When the entry is added to the ledger, it compares its version to the current version. If the versions don’t align, the update fails. If they do align, the transaction goes through.

Consider this example to better understand how optimistic locking works. If you and a friend are using peer-to-peer paying apps, like CashApp, at the same time, you might try to send $50 while your friend requests $40. These actions would both influence your account balance.

Optimistic locking doesn’t require the transactions to queue. Instead, it looks at your balance at the time of each transaction, processes both transactions in parallel, and, when it’s time to complete the transactions, checks if your balance’s version has changed.

If the version has changed, the second transaction will be rejected and retried based on your new balance version. This helps avoid a deadlock, but the system may need to retry one of the transactions to get it to go through.

The Benefits and Downsides of Optimistic Locking

The benefits of optimistic locking include:

  • Higher throughput, since transactions are able to happen simultaneously
  • No deadlocks, so reads aren’t blocked by writes

Optimistic locking is ideal for systems where the risk of conflict is low or infrequent, such as read-heavy systems, or for systems with short transactions, which can help users avoid unnecessary wait times

While transaction attempts can happen concurrently, some may fail and require retrying. Those retries can create more complex situations for developers working on databases, and it may not be the best solution if conflicts occur frequently.

How Do Pessimistic and Optimistic Locking Handle Race Conditions in Financial Systems?

Race conditions, which happen when two transactions or processes try to update the same record at the same time, are handled differently by pessimistic and optimistic locking procedures.

  • Pessimistic locking makes transactions queue. A transaction cannot be completed until the one ahead of it has updated the record.
  • Optimistic locking allows transactions to happen simultaneously. Validation is performed when the transactions are committed to the record, which may require retries if the record version has changed.

Both of these processes can handle concurrent transactions. For financial situations in which conflicts are likely and volume is low, pessimistic locking can be a sensible approach. However, for most modern ledger database designs needing immutability and continuous performance, optimistic locking makes more sense, as it is more flexible.

Try Modern Treasury

See how smooth payment operations can be.

Talk to sales
More from

Learn

Ledgers are foundational to any company that moves money at scale. Explore the accounting fundamentals behind the ledgering process, the differences between application ledgers and general ledgers, and more.

A chart of accounts (COA) is an index of all the different accounts within a company’s ledger.

Read more

A digital wallet (also sometimes called an electronic wallet) is an application that securely stores digital payment information and password data for a user.

Read more

A Ledger Database is a database that stores accounting data. More specifically, a ledger database can store the current and historical value of a company’s financial data.

Read more

Pessimistic locking and optimistic locking are types of concurrency controls designed to handle concurrent updates in a ledger system, helping prevent race conditions and maintain immutability in financial ledgers.

Read more

Learn the difference between Single-Entry Accounting and Double-Entry Accounting

Read more

Data immutability is the idea that information within a database cannot be deleted or changed. In immutable—or append-only—databases, data can only ever be added.

Read more

ACID stands for Atomicity, Consistency, Isolation, and Durability—the four rules that keep database transactions running smoothly. Together, they ensure every transaction is reliable, predictable, accurate, and intact.

Read more

Every Account in a double-entry ledger is categorized as debit normal or credit normal. Debit-Normal Accounts represent uses of funds (assets, expenses); Credit-Normal Accounts represent sources of funds (liabilities, equity, revenue).

Read more

In the context of software, concurrency control is the ability for different parts of a program or algorithm to complete simultaneously without conflict. Concurrency controls in a database ensure that simultaneous transactions will be parsed appropriately.

Read more

An API call is idempotent if it has the same result, regardless of how many times it is applied. Inadvertent duplicate API calls can cause unintended consequences for a business, idempotency helps provide protection against that.

Read more

A ledger API allows companies who need to move money at scale quickly and easily access, track, audit, and unify all of their financial data in one place.

Read more

The ledger balance, also called the current balance, is the opening amount of money in any checking account every morning. The ledger balance should remain the same for the duration of the day.

Read more

A ledger (also called a general ledger, accounting ledger, or financial ledger) is a record-keeping system for a company’s financial transaction data.

Read more

A subsidiary ledger is used to keep track of the details for a specific control account within a company’s general ledger.

Read more