MySQL相关问题

Mysql三大日志是什么?

首先mysql三大日志分别的 undolog、redolog 、 binlog;

undo-log:主要的用途是用来保证mysql事务的原子性;它是配合mvcc实现事务的回滚;undolog是innodb存储引擎的日志;它把更新前的数据记录保存在undo log中,需要回滚的时候就利用undo log来进行回滚;

redolog:redo-log是innodb存储引擎的日志;它主要的保证了数据的持久性,用于在故障恢复;它记录了某个数据页做了什么修改;然后mysql写入数据,是通过WAL来进行的,即先写日志,后刷盘;提高了写入的效率;

binlog:binlog是service层的日志,是每一个存储引擎都有的日志;它主要用于数据备份和数据迁移;它存储了每一条更新操作的原始语句,完成一条更新操作后就会写入binlog,然后统一刷入binlog文件;

redolog和binlog的区别和应用场景?

区别:

一、redolog是innodb存储引擎特有的日志,而binlog是service层的日志,是所有存储引擎都有的日志;

二、文件格式不一样:binlog有三种文件格式,默认的是statement 、row 、mix;statement是存储原始更新数据 row存储的是更新数据后的结果;mix的两者的混合模式;redolog记录的是在某某页修改了什么;

三、redolog主要用于故障恢复;binlog主要用于数据备份和数据迁移;

四、写入文件的方式不同:redolog是循环写;binlog是持续写;redolog文件假如写满了就会刷入磁盘清空文件 循环在一个文件中写;binlog一个文件写满后就会创建一个新的文件进行写入;

redolog和binlog 在恢复数据库有什么区别?

binlog是追加写,写满了一个文件就会创建一个新的文件继续写,保存的是全量的数据,可以恢复数据库任意时刻的数据;

redolog是循环写,日志空间大小是固定的,全部写满了就从头开始,保存的innodb存储引擎对数据页的修改,用于因中途故障丢失的脏页数据;

相关推荐
梦里不知身是客1131 分钟前
kettle的mysql 根据条件,导出到不同的excel中
数据库·mysql·excel
sanggou41 分钟前
踩坑记录:PDManer 导出 Oracle DDL 默认值成 ‘NULL‘ 字符串的排查与解决
数据库·oracle
动亦定43 分钟前
MySQL 锁等待超时错误。详细解释原因和解决方案
数据库·mysql
脚踏实地的大梦想家1 小时前
【Docker】P5 Docker Compose 实战指南:一键部署 WordPress + MySQL
mysql·docker·容器
数据库学啊1 小时前
分布式数据库架构设计指南:TDengine如何支持10亿级数据点的水平扩展
数据库·分布式·时序数据库·数据库架构·tdengine
郝学胜-神的一滴1 小时前
Qt删除布局与布局切换技术详解
开发语言·数据库·c++·qt·程序人生·系统架构
小丁爱养花2 小时前
Redis - set & zset (常用命令/内部编码/应用场景)
数据库·redis·缓存
李慕婉学姐2 小时前
【开题答辩过程】以《基于微信小程序的线上讲座管理系统》为例,不会开题答辩的可以进来看看
javascript·mysql·微信小程序
GottdesKrieges3 小时前
OceanBase集群诊断工具:obdiag
数据库·sql·oceanbase
大G的笔记本4 小时前
用 Redis 的 List 存储库存队列,并通过 LPOP 原子性出队来保证并发安全案例
java·数据库·redis·缓存