持久化的定义:
- 数据,存到磁盘或者文件当中。
- 机器重启后,数据不会丢失。内存 -> 磁盘的映射,和序列化有些像。
ZooKeeper 的持久化:
- SnapShot 快照,记录内存中的全量数据
- TxnLog 增量事务日志,记录每一条增删改记录(查不是事务日志,不会引起数据变化)
持久化的作用:
快照的缺点,文件太大,而且快照文件不会是最新的数据。 增量事务日志的缺点,运行时间长了,日志太多了,加载太慢。二者结合最好。
快照模式:
- 将 ZooKeeper 内存中以 DataTree 数据结构存储的数据定期存储到磁盘中。
- 由于快照文件是定期对数据的全量备份,所以快照文件中数据通常不是最新的。
见图片: