This article comes from the public number: Hook hook Java universe (wechat: Javagogo), mo to promote, all dry goods!
By Bing Yue
MySQL consistency logs
If the MySQL database is powered down, what about uncommitted transactions?
Answer: By journaling.
Before performing an operation, the database writes the contents of the operation to the file system log before performing the operation. In the event of an outage or power outage, even if the operation is not completed, but the log has been written before the operation, we can still recover according to the log content.
The MySQL InnoDB engine has redo logs, undo logs, and binary logs related to consistency.
- redo log
Every time an operation is executed, it is written to the redo log before the data actually changes. In this way, if subsequent tasks cannot be completed due to an accident such as a power failure, you can continue to complete these changes after the system recovers.
- undo log
Corresponds to redo logs, also called undo logs, which record the state of data before a transaction begins.
When some changes cannot be completed due to an accident in the middle of execution, you can revert to the state before the change based on the undo log.
For example, transaction T1 updates data X from 10 to 20. Redo log
and Undo log
.
- binlog
MySQL Sever layer maintains a binary log, one of the most important MySQL log, it records all DDL and DML statements, in addition to the data query statements select, show, etc., but also contains the consumption time of the statement execution.
Unlike redo/undo logs in InnoDB engine, binlogs are mainly used for replication and recovery. Binlogs are used to record SQL statements that update or potentially update MySQL data and are stored on disk as transaction logs.
Binlog is mainly used in the master-slave replication process of MySQL. The MySQL cluster enables binlog on the Master end, the Master transfers its binary log to slaves, and then the slave node plays back to achieve the consistency of master-slave data.
You can connect to the MySQL server and use the following command to view the actual binlog data:
// Show binlog events; Show binlog events in 'mysql-bin.000001 '; // show master status\G // show binary logs;Copy the code
How is the XA specification defined
XA is a distributed Transaction specification proposed by X/Open organization. The XA specification mainly defines the interface between Transaction Manager and Resource Manager.
- Transaction Manager
Because XA transactions are based on the two-phase commit protocol, a coordinator is required to ensure that all transaction participants have completed the preparation, which is phase 1 of 2PC.
If the transaction coordinator receives a message that all participants are ready, it is notified that all transactions are ready to commit, phase 2 of 2PC.
The introduction of a transaction coordinator is necessary because in a distributed system, two machines cannot theoretically reach a consistent state and a single point of coordination needs to be introduced.
- Resource Manager
Responsible for controlling and managing real resources, such as databases or JMS queues.
XA support is currently available in major databases, and transaction support is defined based on XA in the JMS specification, the Java Message Service.
The execution flow of XA transactions
XA transaction is an implementation of two-phase Commit. According to 2PC specification, XA divides a transaction into two phases, namely Prepare and Commit.
- Prepare stage
TM sends a prepare command to all RMS. After receiving the command, THE RM modifies data and logs data. Then, the RM returns a message that can be submitted or not submitted to TM.
If the transaction coordinator TM receives a message that all participants are ready, all transaction commits are notified and the second phase is entered.
- The Commit phase
After receiving the prepare result from all The RMS, TM sent the Rollback command to all the RMS if the prepare result was invalid or timed out.
If all RMS return Commit, issue Commit to all RMS to complete a transaction.
How does MySQL implement the XA specification
There are two types of XA transactions in MySQL, internal XA and external XA. The difference is that the transaction takes place on a single MySQL server or between multiple external nodes.
- Internal XA
In MySQL’s InnoDB storage engine, when binlog is enabled, MySQL maintains both binlog and InnoDB’s redo log. To ensure consistency between the two logs, MySQL uses XA transactions. It is called internal XA because it works on a MySQL single machine.
The internal XA transaction is coordinated by binlog. When the transaction commits, the commit information needs to be written to the binary log, that is, the binlog participant is MySQL itself.
- External XA
External XA is a typical distributed transaction. MySQL supports SQL statements such as XA START, END, PREPARE, and Commit. You can use these commands to complete distributed transactions.
You can also check out the MySQL documentation for more XA commands.
MySQL external XA is mainly applied in the database agent layer to achieve distributed transaction support for MySQL database, such as the open source database middle layer, such as TDDL of Taobao and Cobar of Alibaba B2B.
External XA is typically for distributed transactions that span multiple MySQL instances, requiring the application layer to act as the coordinator, for example when we are writing business code that decides whether to commit or rollback, and recover in the event of a crash.
The Xid binlog
When a transaction commits, an additional Xid structure is added to the binlog-dependent internal XA, which has multiple data types:
- The statement is a basic statement, including Commit
- Row format, the record is row-based
- Mixed format, logging uses a mixed format
In both statement and row format, the binlog will add an XID_EVENT as the end of the transaction. This event records the transaction ID (Xid) and determines how to recover the MySQL crash based on the status of the commit in the binlog.
Binlog Synchronization process
Write redo log, then write binlog, and write binlog successfully.
When a transaction commits:
-
InnoDB enters the Prepare phase and writes /sync redo log and redo log to the redo log. Binlog does nothing
-
Write /sync binlog, write binlog, also write xID to binlog
-
InnoDB engine commit, write commit information to redo log
-
If the first and second steps fail, the entire transaction is rolled back
-
If the xID fails in the third step, MySQL checks whether the XID has been committed after the restart. If the xID has not been committed, the transaction needs to be executed again. In this case, MySQL performs another commit in the storage engine to ensure the consistency between the redo log and binlog data and prevent data loss.
MySQL supports user customization of how to flush logs from the log buffer to the log file at commit time. This is determined by the value of the variable innodb_flush_log_at_trx_Commit.
The contents of the log buffer are called dirty logs. If you are interested, you can look them up.
Welcome big guys to pay attention to the public account of the Java universe (wechat: Javagogo), refuse hydrology, harvest dry goods!