Author: Lin Guanhong/The Ghost at my Fingertips
The Denver nuggets: juejin. Cn/user / 178526…
Blog: www.cnblogs.com/linguanh/
Making: github.com/af913337456…
Tencent cloud column: cloud.tencent.com/developer/u…
Worm hole block chain column: www.chongdongshequ.com/article/153…
Before the order
It has been more than two months since the last publication. The year of 2018 is coming to an end, and my current work is still related to blockchain applications. I am also honored to be invited to sign a contract to publish a book tentatively titled “Blockchain Ethereum DApp Practical Development” in early September, which is expected to be published early next year.
The reason that makes me feel to record this article is that when I used Go language to rewrite an exchange order matching module originally written by PHP language recently, I found that part of the order matching code adopted the operation of global locking table in order to ensure that the data of each table would not appear messy in the case of concurrent reading and writing. Later, I modified it in the form of shared lock, which was just rewritten, and conducted a concurrent unit test, and the performance was normal.
directory
- Scene description
- To solve the problem
- Order matching example
- Shared locks and exclusive locks
- Front knowledge
- Row and table locks
- Two types of row lock features
- Two kinds of row lock lock
- The release of the lock
- Operation example
- Modifying snippets
Scene description
There are many types of highly concurrent services, the most common being for example, seckilling. They all have a common characteristic that data updates are frequent, usually involving the operation of adding and changing multiple business tables, and the more tables there are, the more problems to be considered.
Order matching can be understood as order buying and selling. Take this as an example to illustrate a situation that may lead to data confusion. So let’s say we’re buying and selling phones, so user A is buying phones, and user B is selling phones. The buy order of A is order 1, and the sell order of B is order 2. The mobile phone is sold in order 2, and the price of A mobile phone is 1000 yuan. At this time, the balance of A’s online wallet is 1001 yuan, which is just higher than the price of the mobile phone, so it can be closed.
A data table records the amount of money in the user’s wallet. Update this table every time you spend money or add money.
When the two orders are entered into the system, they are matched. Assume that the order matching operation process of the system is as follows:
When determining the balance of user A’s wallet, 1001 > 1000 is found, and the result is passed. At this time, it is ready to enter the step of “Record more details”. However, during the time difference in this process, user A used the online withdrawal function of the system and successfully transferred 10 yuan, and the remaining 1001-10 = 991 yuan. However, due to the balance judgment process and the passing of the matching system, the following transaction process can still be carried out. Finally, A bought B’s mobile phone priced at 1000 yuan with 991 yuan.
To solve the problem
The above FAQ is a very simple model; real-world systems tend to be more complex. But the problems are real, and there are many solutions to them. Among other things, you can consider using database locks.
This article will introduce MySQL database shared lock and exclusive lock, other not explained or extended.
Order matching example
The following screenshot is the original PHP code of the matchmaking system that I rewrote, which uses the way of table lock to solve the previous problem of messy data caused by concurrent read and write. This approach solves the problem, but results in poor performance.
Shared locks and exclusive locks
Pre-knowledge:
- MySQL is a database, not a database
Database engine
- MySQL has two common storage engines:
MyISAM
andInnoDB
MyISAM
Transaction operations are not supported,InnoDB
Support transaction operations- MySQL lock points have
Row locks
和Table locks
- MyISAM only has table locks
- Innodb row locks, table locks
- There in the row locks
A Shared lock
andExclusive lock
A Shared lock
S-lock for short,Exclusive lock
Hereinafter referred to as X lock
Row and table locks
Description:
-
Row lock, which locks the corresponding row in the table and only restricts the read and write of the current row.
-
A table lock locks the entire table and restricts data reads and writes to the entire table.
Comparison:
- Line lock, computer resource overhead, slow lock; There will be a
A deadlock
; The lock granularity is minimum and the probability of lock conflict is lowest.Concurrent degree
Highest, high performance. - Table lock, the cost of computer resources is small, fast lock; There will be no
A deadlock
; The lock granularity is large and the probability of lock conflict is highest.Concurrent degree
Lowest, low performance.
Two types of row lock features
A Shared lock
A has A shared lock on data B. A can read and modify data B, and C can only read data B, but cannot modify data B. Until A releases B’s lock.
Exclusive lock
A has an exclusive lock on data B. A can read and modify data B, C and other data can not be locked on data B. The intuitive experience is that it cannot be modified and cannot be read using select with lock action.
Two kinds of row lock lock
Note that:
- SQL statements must have index restrictions, such as row lock
where id=xxx
This kind of statement. - The implementation of row locks SQL statements without index constraints will become
Table locks
InnoDB engine
The defaultModify the data
SQL like statement,update
.delete
.insert
Etc., will automatically add exclusive locks to the data involved.
A Shared lock
- Select can be added using one of the following formats:
select ... Where index limit lock in share mode
In the statement. For example, select name from lGH_user where ID = 1 lock in share model. In this case, the ID is the index.
Exclusive lock
- Meet the format:
select ... Where index limits for update
The statement of
The release of the lock
-
In a non-transaction Transaction, the lock is released after the statement completes execution.
-
A row lock in a Transaction cannot be released until the current Transaction has been committed or rolled back.
Operation example
To illustrate the example in transaction TX, text parsing is shown in figure.
Modifying snippets
All table locks in the match are replaced with shared locks, and other services are run to read the locked row data. No modification is allowed until the batch operation of the current transaction is completed.