Skip to content

Commit

Permalink
Update the memory usage size of a transaction #8316 (#7893) (#8660)
Browse files Browse the repository at this point in the history
  • Loading branch information
ti-chi-bot authored May 17, 2022
1 parent fd3ed0e commit a2b30d3
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 1 deletion.
20 changes: 20 additions & 0 deletions pessimistic-transaction.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,26 @@ The `BEGIN PESSIMISTIC;` and `BEGIN OPTIMISTIC;` statements take precedence over

Pessimistic transactions in TiDB behave similarly to those in MySQL. See the minor differences in [Difference with MySQL InnoDB](#difference-with-mysql-innodb).

- For pessimistic transactions, TiDB introduces snapshot read and current read.

- Snapshot read: it is an unlocked read that reads a version committed before the transaction starts. The read in the `SELECT` statement is a snapshot read.
- Current read: it is a locked read that reads the latest committed version. The read in the `UPDATE`, `DELETE`, `INSERT`, or `SELECT FOR UPDATE` statement is a current read.

The following examples provide a detailed description of snapshot read and current read.

| Session 1 | Session 2 | Session 3 |
| :----| :---- | :---- |
| CREATE TABLE t (a INT); | | |
| INSERT INTO T VALUES(1); | | |
| BEGIN PESSIMISTIC; | |
| UPDATE t SET a = a + 1; | | |
| | BEGIN PESSIMISTIC; | |
| | SELECT * FROM t; -- Use the snapshot read to read the version committed before the current transaction starts. The result returns a=1. | |
| | | BEGIN PESSIMISTIC;
| | | SELECT * FROM t FOR UPDATE; -- Use the current read. Wait for the lock. |
| COMMIT; -- Release the lock. The SELECT FOR UPDATE operation of session 3 obtains the lock and TiDB uses the current read to read the latest committed version. The result returns a=2. | | |
| | SELECT * FROM t; -- Use the snapshot read to read the version committed before the current transaction starts. The result returns a=1. | |

- When you execute `UPDATE`, `DELETE` or `INSERT` statements, the **latest** committed data is read, data is modified, and a pessimistic lock is applied on the modified rows.

- For `SELECT FOR UPDATE` statements, a pessimistic lock is applied on the latest version of the committed data, instead of on the modified rows.
Expand Down
2 changes: 1 addition & 1 deletion transaction-overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -292,7 +292,7 @@ Due to the limitations of the underlying storage engine, TiDB requires a single
TiDB supports both optimistic and pessimistic transactions, and optimistic transactions are the basis for pessimistic transactions. Because optimistic transactions first cache the changes in private memory, TiDB limits the size of a single transaction.
By default, TiDB sets the total size of a single transaction to no more than 100 MB. You can modify this default value via `txn-total-size-limit` in the configuration file. The maximum value of `txn-total-size-limit` is 10 GB. The individual transaction size limit also depends on the size of remaining memory available in the server. This is because when a transaction is executed, the memory usage of the TiDB process is scaled up comparing with the transaction size, up to six and more times of the transaction size.
By default, TiDB sets the total size of a single transaction to no more than 100 MB. You can modify this default value via `txn-total-size-limit` in the configuration file. The maximum value of `txn-total-size-limit` is 10 GB. The individual transaction size limit also depends on the size of remaining memory available in the server. This is because when a transaction is executed, the memory usage of the TiDB process is scaled up comparing with the transaction size, up to two to three times or more of the transaction size.
TiDB previously limited the total number of key-value pairs for a single transaction to 300,000. This restriction was removed in TiDB v4.0.
Expand Down

0 comments on commit a2b30d3

Please sign in to comment.