“This is the first day of my participation in the First Challenge 2022. For details: First Challenge 2022.”

In this first article of 2022, I would like to talk about two small things in mysql: redo log and binlog.

Redo log: InnoDB stores engine logs, so if you use a non-InnoDB storage engine, there is no redo log.

Binlog: the MySQL Server layer logs, so no matter what storage engine is used, as long as the MySQL will have a binlog existence, in the MySQL primary/secondary replication, use the binlog.

Now, let’s take a closer look at what they do.

redo log

Why do I have a redo log file?

In this case, we can take an example. Now we want to modify the data in the database, and an update statement comes in. Normally, the update operation is accompanied by the query operation, so we need to find the data first, and then update the data.

If the amount of data is small, fine, it can be found and updated quickly, but if the amount of data is large, it has 100 million pieces of data, what do you do? And updates must be written to disk, so what about the IO cost?

What if I have dozens of update statements? So if you think about it that way, you can say, well, just doing these things, the costs are going to be high. No, can we reduce those costs?

This is where the redo log comes in. When a record is updated, the InnoDB engine writes the record to the redo log and updates the memory.

But at this point, it’s not being updated to disk, right? Don’t worry InnoDB will update this entry and record to disk in due course.

WAL, or WriteAheadLogging, is an idea or technique that has its own name: Write to the log first, and then write to the disk.

You can’t write redo logs all the time, right?

The size of the redo log is fixed. The redo log is overwritten, and once full, the redo log is synchronized to disk to make room for subsequent changes.

If the database is down or restarted, data will not be lost.

Because of the redo log, previously committed records remain. You only need to restore the redo log.

binlog

Binlog is the record log of MySQL Server layer.

Redo log and binlog:

  • Redo logs are unique to InnoDB; Binlog is implemented in the Server layer of MySQL, all engines are available.

  • The redo log is a physical log of “XXX changes made on XXX page”. Binlog is a logical log, such as “add 1 to the C field on the line id = 2”.

  • The redo log has a fixed size, so it runs out of space. If it runs out, you must do some writing to disk before continuing. The binlog can be appended, so there’s no space in the binlog, just keep writing.

Binlog records all DDL and DML statements as events (because it records operations rather than data values, it is a logical log) and can be used for master slave replication and data recovery.

With the binlog function enabled, we can export the binlog into SQL statements and replay all operations to achieve data recovery.

With these two logs in hand, let’s look at how an update statement is executed (redo cannot be written all at once) :

Update user set name=’ colt ‘where id=1;

  1. This is the first query for this data, if there is a cache, will also use the cache.

  2. Change name to pony, then call the engine API, write this line to memory, and log the redo log. The redo log enters the prepare state and tells the executor that execution is complete and can be committed at any time.

  3. After receiving the notification, the executor logs the binlog, then calls the storage engine interface and sets the redo log to commit.

  4. Update complete.

You can find that the redo log is in the prepare state and the commit state after the binlog is finished. This method is called “two-phase commit”. Why is it that way?

Both redo log and binlog can be used to represent the commit state of a transaction, and two-phase commit is to keep the two states logically consistent.

Suppose instead of doing this, you write redo logs and then binlogs. If an exception occurs while writing to the redo log, and the redo log is not updated, is there a data inconsistency?

The same is true for binlog and redo log. Keep the redo log in the prepare state and the redo log in the commit state after the binlog is finished.

summary

Mysql: redo log: binlog: log: log: binlog: log: log: log: log: log: log: log: log: log: log: log: log: log: log: log: log: log

The recent chase beginning to 13 episodes, was zhao this circle of wheat powder, love love, watching the ending I want to 13 episodes also clear, meng-meng wang should like tying into the circulation, estimates that is why the bus driver wants to pull the car go to dead, the last cycle ending, men really death, bus drivers and aunt know her daughter’s cause of death, Also to see the greatness of his daughter, finally they give up explosion plan, the inside of the bus are saved, and then, the final is tying a dream, she unwilling, she wanted to save all the people on the bus, she cycle time and time again, she didn’t want to wake up and finally she saved all successful people, wake up is a dream, because the reality is that happened, The whole cycle is also in the heroine’s dream.

Finally, hope is better, we don’t bring our negative feelings to others, hurt others. 2022, come on! Less talk, more action