redo log 和 binlog
MySQL有哪几种日志?
两种日志:redo log 和 binlog
区别:
- redo log 是 InnoDB 引擎特有的;binlog 是 MySQL 的 Server 层实现的,所有引擎都可以使用。
- redo log 是物理日志,记录的是“在某个数据页上做了什么修改”;binlog 是逻辑日志,记录的是这个语句的原始逻辑,比如“给 ID=2 这一行的 c 字段加 1 ”。
- redo log 是循环写的,空间固定会用完;binlog 是可以追加写入的。“追加写”是指 binlog 文件写到一定大小后会切换到下一个,并不会覆盖以前的日志。
为什么MySQL要写到redo log buff内存?
因为写进磁盘IO成本很高,先写buff,再写到日志,就当成功了,等空闲时写入磁盘。
redo log主要有什么用?
有了 redo log,InnoDB 就可以保证即使数据库发生异常重启,之前提交的记录都不会丢失,这个能力称为 crash-safe。
提交之后100%落盘吗?
不一定,但是两阶段提交可以保障一致性
主从同步
mysql 主从同步过程?
- 在备库 B 上通过 change master 命令,设置主库 A 的 IP、端口、用户名、密码,以及要从哪个位置开始请求 binlog,这个位置包含文件名和日志偏移量。
- 在备库 B 上执行 start slave 命令,这时候备库会启动两个线程,就是图中的 io_thread 和 sql_thread其中 io_thread 负责与主库建立连接。
- 主库 A 校验完用户名、密码后,开始按照备库 B 传过来的位置,从本地读取 binlog,发给 B。
- 备库 B 拿到 binlog 后,写到本地文件,称为中转日志(relay log)。
- sql_thread 读取中转日志,解析出日志里的命令,并执行。
如果有一台新机器要加到从机里,怎么个过程。
MySQL 主从复制主要有几种模式?
【152期】面试官:你能说出MySQL主从复制的几种复制方式吗?
-
异步复制
-
多线程复制
-
增强半同步复制
-
binlog 日志是 master 推的还是 salve 来拉的?
slave去拉 -
数据库是怎么保证一定不会丢失数据的?
只要 redo log 和 binlog 保证持久化到磁盘,就能确保 MySQL 异常重启后,数据可以恢复。
Mysql是集群和单节点