MySQL database two-phase commit, do you know? This article will briefly discuss the two-phase commit process in MySQL database. Two-phase commit occurs during data changes (update, delete, add, etc.). The two-phase commit process involves two logging systems in MySQL database: redo log and binlog files.
MySQL server provides binlogs. Binlog is a binary file that all storage engines can use. Binlog is a logical log that is appended to. The original logic for executing statements is recorded. After a file is written to a specified size, it will be switched to the next file to continue writing. The log file that has been written before will not be overwritten.
The binlog file is mainly used for data recovery and data synchronization between servers in the cluster environment. In the work, we delete data or tables by mistake. If we need to restore the data, we use the binlog log to recover.
Now that we know about these two logs, we will focus on the MySQL database two-phase commit. Previously, we said that two-phase commit occurs during data changes. To better understand the two-phase commit, we will use an update command.
mysql> update T set c=c+1 where id=2;
Copy the code
MySQL > update c = 0; MySQL > update c = 0; Here’s an execution flow chart:
As you can see from the flowchart, an update statement executed within MySQL with InnoDB storage engine goes through the following five steps:
-
1. The executor first fetches the data line ID=2 from the engine. If the data page id=2 is already in memory, it will be directly returned to the executor; Otherwise, you need to read into the memory from disk and then return.
-
2. The actuator takes the row data given by the engine and adds 1 to the value. For example, it used to be N, but now it is N+1 to get a new row of data.
-
3. The redo log is prepared when the engine updates the data to memory and logs the update to the redo log. The executor is then told that the execution is complete and the transaction can be committed at any time.
-
4. The executor generates a binlog of the operation and writes the binlog to disk.
-
5. The executor calls the commit transaction interface of the engine, and the engine changes the redo log to commit.
Note that the redo log is split into two commit phases: Prepare and COMMIT. This process is called a two-phase commit.
To prove this, we can use a back-step method. If we do not use two-phase commit, we have two commits: redo log and then binlog, and redo log and then binlog.
Write redo log and then binlog. MySQL restarts unexpectedly when the redo log is complete. The value of C was 1 after the redo log was restored, but the binlog was not finished, so the update statement was not recorded in binlog. If the binlog file is used to restore the temporary database, the c value of the restored row id =2 is 0, which is inconsistent with the original database value.
Write binlog and redo log. If the system crashes after the binlog and redo log is not written, and the system restarts, the c value of the row with id=2 is still 0, but the update is recorded in the binlog file. If you need to restore the temporary library using the binlog file, the system crashes after the system restarts. Then the value of c in the row where id=2 is 1, which is inconsistent with the value of the original library.
From these two assumptions, we can see that data inconsistency may occur regardless of which log file is committed first. The log file two-phase commit technique solves the problem of inconsistency between redo and binlog files, thus ensuring data consistency during data recovery.
The above is the two-stage submission involved in MySQL data editing. I hope this article is helpful to your study or work. If you think it is helpful, please help forward it.
The last
At present, many big names on the Internet have MySQL related articles, if there is the same, please forgive. The original is not easy, the code word is not easy, but also hope you support. If there are mistakes in the article, please also put forward, thank you.
Welcome to scan the code to pay attention to wechat public number: “Internet flathead brother”, brother Peace study together, progress together.