RocketMQ三种刷盘策略笔记
PageCache高速页缓存:Linux系统自带的一块缓存区,是Linux对文件的缓存,用于加速对文件的读写。Linux会将一部分内存作为PageCache。
-
同步刷盘:消息被写入PageCache后立即刷盘,只有当消息被持久化到磁盘后才会响应ACK。
-
异步刷盘:消息在被写入PageCache后就会响应ACK,当PageCache里的消息积累到一定量后,由OS线程将PageCache里的消息刷入磁盘。注:如果RocketMQ服务挂了,PageCache里的消息并不会丢失,因为PageCache是属于Linux系统的缓冲区,只有当服务器突然断电才会导致消息丢失。
-
异步刷盘+缓冲区:RocketMQ将一部分内存当做缓冲区,消息被写入内存缓冲区后就返回ACK,由后台程序将内存缓冲区里的消息刷入磁盘。注:在该模式下,RocketMQ服务宕机或服务器突然断电都会导致消息丢失。
同步刷盘:最可靠,性能低
异步刷盘:较为可靠,性能较高
异步刷盘+缓冲区:不太可靠,性能最高