2022-1-1
往aof文件中记录命令的格式为redis网络通信时的resp协议。
aof文件采用了最普通的文本协议,优势:1文本协议兼容性高,2可手动更改aof文件。
由于redis是单线程,所以使用aof缓冲区暂存数据,否则直接落盘会影响redis的性能。
aof缓冲区数据同步到aof文件的时机由redis.conf中appendfsync参数决定。
appendfsync always/eversec/no aof缓冲区数据写入aof文件时的同步策略。
涉及操作系统的write命令、fsync命令、io缓冲区
always 一旦aof缓冲区有数据时,就调用fsync命令强制往aof文件写数据(redis性能最差,数据可控性最好)
eversec (默认)一旦aof缓冲区有数据时,就调用write命令往io缓冲区写数据,同时每秒调用一次fsync命令强制将io缓冲区的数据写入到aof文件(redis性能、数据可控性适中)
no 一旦aof缓冲区有数据时,就调用wirte命令往io缓冲区写数据。由操作系统定期或当io缓冲区填满时,自动将io缓冲区的数据写入到aof文件(redis性能最好,数据可控性最差)
总结:always只调用fsync,no只调用write,eversec既调用wirte,又每秒调用一次fsync
write命令和fsync命令的区别:
wire命令只能确定数据成功写入io缓冲区。数据是否成功写入aof文件,是由操作系统定期或当io缓冲区填满时,
自动将io缓冲区的数据写入到aof文件。所以在io缓冲区的数据存在断电数据丢失的风险。
fsync命令具有强制将io缓冲区数据写入到aof文件的机制,可以确定数据是否成功写入aof文件。
java中write即write命令,flush即fsync命令。两个命令的使用是由于操作系统的机制决定的