存储的同步复制技术,一般是底层数据块的复制,对上层应用是无感知的,那上层应用如果是数据库的话,数据库是有缓存的,如果在没有commit之前主机房发生故障,系统宕机,那在容灾端恢复的数据是完整的吗?如何保证数据一致性呢?
1. 开发人员应该减少长事务的运用。
2. 存储同步复制中,有一些高端产品,号称未提交到磁盘,在内存中的数据依然能够复制。
3. 大部分基于磁盘卷保护的产品,存储,CDP都认为没有提交到磁盘的数据属于脏数据。
4. 如果谈到两个数据中心的灾备保护,那么CDP产品多数应用于异步环境,那么未提交的数据在这种场景下没有保护的必要。
5. 数据库复制技术我们会找专门的专题来讨论,数据库是可以通过回滚技术实现一部分数据的恢复。
收起数据库事物虽然没有没有COMMIT,但是事物日志中有记录,基于同步复制,灾备端的存储上也会有相应的事物日志记录,如果这时主机故障宕机,灾备端的数据库是可以根据该事物日志的记录进行自我恢复的。就如同该宕机主机启动后恢复的过程一样。
收起