是的,MySQL的redo log主要是用于记录InnoDB存储引擎中的事务操作。因为InnoDB存储引擎是支持事务的,它通过redo log来保证事务的ACID特性,即原子性、一致性、隔离性和持久性。
在InnoDB中,当一个事务执行时,它会将所有的修改操作记录到内存中的redo log缓冲区中。当事务提交时,redo log中的所有操作会被持久化到磁盘中的redo log文件中。这样,在系统发生故障时,MySQL可以使用redo log文件中的操作重新执行一遍,将数据库恢复到故障前的状态。
需要注意的是,redo log只是记录事务操作,而不是所有的数据库操作。因此,如果使用的是非事务性存储引擎(如MyISAM),则不会有redo log。此外,由于InnoDB存储引擎只记录对表空间的修改,因此对非InnoDB存储引擎中的表的修改也不会被记录到redo log中。
综上所述,MySQL的redo log只是记录InnoDB存储引擎中的事务操作,通过redo log来保证事务的ACID特性,并在数据库故障时实现数据的恢复。